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I.  INTRODUCTION 


A.  THE  MOTIVATION 

In  recent  years,  the  rapidly  growing  demand  for  transfer  of  a  massive  amount  of 
data  between  computing  devices  has  led  to  a  great  deal  of  work  towards  improving 
network  performance.  Data  transfer  rates  in  networks  have  evolved  from  Kilobits  per 
second  to  rates  of  10  Megabits  per  second  in  CSMA/CD  networks.  The  rapid  progress 
in  the  processing  power  of  workstations,  the  use  of  fiber  optics  as  transmission  medium, 
and  the  increased  user  expectations  for  performance  have  spurred  development  of  a  new 
standard  for  local  area  networks  which  achieves  rates  of  100  Megabits  per  second.  This 
standard,  the  Fiber  Distributed  Data  Interface  (FDDI)  is  a  token-passing  ring  local  area 
network  recently  developed  by  the  American  National  Standard  Institute  (ANSI) 
Accredited  Standards  Committee  (ASC  X3T9.S).  FDDI  has  a  1(X)  Megabits  per  second 
csqncity  which  enables  it  to  meet  the  bandwidth  requirements  for  many  iq>plications. 

Originally,  FDDI  was  proposed  by  the  ANSI  X3T9.5  as  a  backmd  network 
between  mainframe  computers  and  their  peripherals.  The  volume  of  data  being  moved 
or  stored  has  reached  proportions  that  dictate  development  of  a  high-p^ormance 
interconnection  among  these  computing  devices.  In  the  course  of  its  development,  new 
demands  were  brought,  which  in  turn  were  accommodated  by  the  emerging  FDDI.  As 
a  result,  the  committee  expanded  the  scope  of  FDDI  to  emphasize  its  application  as  a 
high-speed  backbone  network  interconnecting  other  heterogeneous,  lower-speed  local  area 
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networks  such  as  token  ring  802.S  and  CSMA/CD.  With  the  proliferation  of  the  new 
powerful  workstation-based  computing  environment,  large  and  growing  use  of  FDDI 
networks  is  expected. 

The  new  FDDI  protocol  can  still  be  improved  to  achieve  higher  network 
throughput.  Lundy  [Ref.  11]  identifies  inefficient  use  of  network  resources  as  one 
problem  faced  by  this  protocol.  Lundy  proposes  alternative  transmission  procedures  to 
increase  the  total  network  throughput  by  a  factor  of  three  to  four  times  that  of  FDDI. 

B.  THE  SCOPE  OF  THESIS 

The  goal  of  this  research  is  to  examine  the  suggested  alternative  transmission 
procedures  which  ideally  raise  the  utilization  to  300  Megabits  per  second,  develop  the 
details  of  an  improved  Media  Access  Control  (MAC)  protocol  which  supports  these 
procedures  and  specify  this  MAC  protocol  using  a  formal  model.  Hie  study  investigates 
the  current  MAC  FDDI  standard  and  conforms  the  improved  MAC  protocol  to  the 
specification  contained  in  that  document. 

The  new  MAC  will  satisfy  three  basic  requiremrats.  First,  it  will  allow 
simultaneous  use  of  both  rings.  Seccmd,  it  will  free  a  ring  segment  from  frame  rq)etition 
allowing  creation  of  ring  disjoint  partitions.  Third,  it  will  permit  concurrent  use  of  the 
partitioned  dual  ring  segments  by  two  transmitting  stations.  This  improved  protocol  can 
ideally  achieve  maximum  throughput  of  300  Megabits  per  second  in  a  dual  ring 
attachment  topology. 


To  achieve  the  desired  improvement,  changes  in  the  method  of  access  to  the 
physical  medium  are  needed.  New  protocol  data  unit  formats  and  the  algorithms  to 
substantiate  the  changes  in  the  proposed  access  method  are  important  initial  research 
problems  which  are  addressed.  Another  challenging  problem  in  a  dual  ring  operation  is 
how  to  ad^t  the  configuration  function  of  FDDI  when  a  node  or  link  fails  such  that  the 
same  fault  tolerance  is  maintained?  Furthermore,  since  the  new  transmission  procedures 
break  the  rings  into  disjoint  partitions,  how  can  the  MAC  supervisory  frames  circulate 
entirely  in  one  logical  ring  during  the  initialization  process?  These  and  other  intricate 
problems  are  analyzed  and  solved  with  the  formal  specirication. 

The  specification  in  this  thesis  is  a  detailed  formal  protocol  description  which 
contributes  to  and  enhances  the  standard  document.  First,  it  reduces  documented  protocol 
ambiguities;  a  desired  feature  in  the  interoperability  achievement  among  multivendors. 
Next,  it  allows  proofs  for  protocol  correctness  and  development  of  protocol  test 
procedures.  Finally,  it  further  increases  understanding  of  the  complex  FDDI  protocol. 
This  thesis  provides  a  formal  specification  of  the  improved  FDDI  protocol  using  a  model 
called  systems  of  communicating  machines  [Ref.  8].  This  model  was  chosoi  because  it 
is  an  effective  tool  for  the  specification  of  this  protocol,  providing  flexibility  as  well  as 
a  formal  basis  for  analysis. 

C.  THESIS  ORGANIZATION 

The  thesis  has  six  chs^ters.  Cluq}ter  n  reviews  the  FDDI  network  as  a  background 
for  the  thesis.  The  main  focus  is  on  the  Media  Access  Control  (MAC).  Chapter  m 
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introduces  the  MAC  for  the  improved  FDDI  protocol.  A  timed-token  controlled 
concurrent  access  is  discussed  and  algorithms  to  generate  subtoken  are  analyzed.  Chapter 
rv  provides  the  protocol  MAC  formal  specification.  Discussion  will  include  the  benefits 
of  the  formal  specification,  the  communicating  machines  processes,  and  the  interface 
operations.  Chapter  V  provides  proofs  for  correctness  of  protocol  modules  operation. 
Chapter  VI  concludes  the  thesis  with  a  research  review  and  provides  suggestions  for 
future  work. 
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n.  THE  FIBER  DISTRIBUTED  DATA  INTERFACE 


This  chapter  provides  the  reader  with  information  concerning  the  Fiber  Distributed 
Data  Interface  (FDDI)  network.  The  main  emphasis  of  this  chapter  is  on  the  Media 
Access  Control  (MAC)  layer  which  will  provide  the  background  for  the  work  developed 
in  the  subsequent  chapters. 

A.  HIGH  PERFORMANCE  MULTI-NODE  NETWORK 

The  Fiber  Distributed  Data  Interface  is  a  high-performance  general  purpose  multi¬ 
station  token  ring  network  designed  for  efficient  operation  with  a  peak  data  transmission 
of  100  Megabits  per  second.  FDDI  provides  many  advantages  over  current  LANs  and 
as  a  high  speed  network  it  can  meet  the  requirements  of  many  applications. 

The  FDDI  specification  is  a  set  of  four  standards  being  developed  by  a  Task  Group 
of  Accredited  Standards  Committee  (ASC)  X3T9.S.  The  American  National  Standards 
for  the  physical  layer  PHY  (ANSI  X3. 148-1988)  and  the  Media  Access  Control  (MAC) 
(ANSI  X3. 139-1987)  have  been  approved  and  published.  Other  standards  that  will 
constitute  the  complete  set  are  still  actively  being  modified.  In  addition,  the  ISO/IEC 
JTCl/SC  13  standards  committee  are  processing  the  FDDI  documents  as  International 
Standards.  The  already  approved  documoits  constitute  the  basic  FDDI.  There  are 
extensions  to  the  basic  FDDI  now  in  the  X3  approval  process.  [Ref.  19] 
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1.  The  FDDI  Token  Ring  Architecture 


An  FDDI  network  consists  of  a  set  of  nodes  connected  by  optical  transmission 
media  into  one  or  more  rings.  A  ring  is  a  closed  loop  of  alternating  nodes  connected  by 
the  physical  media.  The  data  is  transmitted  from  node  to  node  serially  over  the  ring  as 
a  stream  of  suitably  encoded  symbols.  Each  node  regenerates  and  repeats  the  data 
downstream  to  the  next  node.  The  network  may  consist  of  hundreds  of  nodes,  although 
no  multivendor  have  built  FDDI  rings  with  a  2(X)  nodes  yet  [Ref.  14]. 

The  X3T9.5  committee  took  the  existing  IEEE  802.5  Token  Ring  protocol 
standard  as  the  basis  for  development  of  FDDI.  These  two  protocols  are  similar  in 
functionality,  however  FDDI  employs  a  timed  token  passing  mechanism  and  uses  fiber 
optics  as  transmission  medium.  Among  other  differences  FDDI  offers  greater  bandwidth 
and  greater  reliability.  While  802.5  token  ring  operates  with  a  maximum  data  rate  of  4 
Megabits  per  second  FDDI  provides  for  efficient  network  operation  with  a  peak  data  rate 
of  100  Megabits  per  second.  In  fact,  FDDI  is  the  first  standard  designed  for  high 
performance  general  purpose  multi-station  network. 

The  token  ring  architecture  of  FDDI  defines  two  rings.  The  first  ring  is  called 
the  primary  ring  and  is  used  in  the  normal  network  operation.  The  second  ring  provides 
redundancy  and  is  used  only  for  reconfiguration  of  the  network  when  a  physical  break 
occurs  on  the  primary  ring.  This  pair  of  rings  forms  the  trunk  ring  of  an  FDDI  network. 
The  data  in  each  ring  flows  in  opposite  directions.  A  timed-token  method  controls  the 
access  to  the  medium.  Further  discussion  on  the  FDDI  medium  access  method  is  given 
in  the  Media  Access  Control  subsection  of  this  chapter. 
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a.  FDDI  Network  Configurations  cmd  Topologies 

Figure  1  illustrates  the  types  of  stations  and  topologies  used  in  FDDI 
networks.  The  figure  shows  the  three  types  of  stations:  DAS,  CON,  and  SAS,  which  are 
defined  by  the  attachment  to  the  ring.  The  Dual  Attachment  Station  (DAS)  is  the  basic 
building  block  of  an  FDDI  network.  It  connects  to  a  pair  of  physical  links  to  carry 
signals  in  opposite  directions.  The  Dual  Attached  Station  has  two  ports  A  and  B;  one  for 
each  ring,  and  attaches  directly  into  the  trunk  ring  in  a  peer  connection.  A  second  type 
of  station  uses  a  concentrator  (CON)  as  a  device  to  provide  the  attachment.  A 
concentrator  has  additional  ports  (master  ports)  beyond  those  required  for  its  own 
attachment  to  the  FDDI  ring.  Concentrators  are  either  Single  Attachment  (SAC)  or  Dual 
Attachment  (DAC).  A  dual  attachment  concentrator  can  attach  directly  to  the  trunk  ring, 
and  provide  the  capability  to  cormect  slave  stations  into  either,  or  both,  of  the  logical 
rings  provided  by  the  trunk  ring.  A  third  type  of  station  is  the  Single  Attachment  Station 
(SAS),  which  has  one  port  (slave  port)  and  therefore  would  not  attach  directly  into  the 
trunk  rings.  Instead,  a  Single  Attachment  Station  connects  only  to  a  concentrator.  The 
Dual  Attached  Stations  or  Dual  Attached  Concentrators  are  also  called  Class  A  stations 
whereas  the  Single  Attached  Stations  are  called  Class  B  stations.  [Ref.  13] 

FDDI  allows  only  one  trunk  ring,  however  cascaded  concentrators  can  attach 
multiple  trees  of  varying  levels.  This  topology  is  called  a  dual  ring  of  trees.  It  combines 
the  advantages  of  a  dual  ting  with  the  advantages  of  a  tree  configuration. 

One  advantage  of  a  dual  ring  design  is  its  superior  reliability  provided  by 
DAS  and  CON.  For  example,  the  dual  counter-rotating  ring  alleviate  the  problem  of 
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Figure  1:  FDDI  Stations  Ccmfiguration  and  Topologies 
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multiple  points  of  failure  within  the  network.  If  a  node  or  link  fails,  the  two  counter¬ 
rotating  paths  wrap  together  around  the  fault,  allowing  communication  to  continue.  In 
this  case  the  configuration  changes  to  the  Wrap  mode.  In  the  Wrap  mode  there  is  a  single 
logical  ring  as  opposed  to  the  normal  configuration  or  Thru  mode,  which  has  a  dual 
logical  ring.  Also,  DAS  may  offer  the  bypass  capability  by  means  of  an  optical  switch. 
This  mechanism  is  useful  if  a  station  for  some  reason  is  removed  from  the  ring  path. 
This  feature  allows  the  remaining  stations  to  continue  in  the  Thru  mode.  Figure  2 
illustrates  these  configuration  changes. 

Another  advantage  of  a  ring  design  is  that  the  optical  fiber  easily 
accommodates  ring  configurations.  This  approach  significantly  reduces  the  size,  cost,  and 
complexity  of  the  hardware  required  by  a  network  since  the  optical  fiber  medium  offers 
high  bandwidth  which  is  best  suited  for  bit-serial  transmission.  [Ref.  12] 

The  tree  topology  provides  fault  tolerance.  For  example,  when  removing  a 
station  or  the  cable  connecting  the  SAS  to  the  CON  fails,  the  bypassing  of  the  failure 
occurs  electronically  within  the  CON.  In  the  cast  where  there  are  many  stations  within 
a  facility,  CON  allow  for  any  number  of  such  failures  or  disconnections  without  affecting 
the  connectivity  of  all  other  stations  on  the  FDDI  network.  Combining  the  dual  ring  and 
the  tree  portions  in  one  topology,  the  resulting  dual  ring  of  trees  provides  a  very  high 
degree  of  fault  tolerance  and  increases  the  availability  of  the  backbone  ring.  [Ref.  7] 
Essentially,  the  improvement  in  the  protocol  modelled  in  this  thesis  is 
achieved  by  the  effective  use  of  both  rings  during  normal  network  operation.  Therefore, 
the  topology  addressed  by  this  protocol  is  a  dual  ring  attachment  configuration.  However, 
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as  the  figure  illustrates,  other  levels  in  the  FDDI  topology  may  use  a  single  attachment 
type  of  station  which  could  not  be  implemented  with  the  improved  protocol  since  the 
secondary  ring  for  these  stations  is  absmt.  This  issue  is  discussed  in  Chaptm*  m. 

An  upward-compatible  version  of  the  initial  FDDI  is  FDDI-n.  FDDI-n 
allows  the  creation  of  an  integrated  services  LAN  because  it  adds  the  capability  for 
circuit  switched  services  to  the  packet  services  of  the  basic  FDDI.  The  concept  behind 
FDDI-n  is  time-division  multiplexing  (TDM)  sixteen  separate  channels^  wilb  eadi 
channel  having  a  maximum  of  98  Megabits  per  second  full  duplex.  FDDHI  is  imended 
for  simultaneous  voice,  video,  and  data  cap^ilities.  This  thesis  uses  the  bosk  FDDI  as 
the  basis  to  model  the  improved  FDDI  protocol. 
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b.  FDDI  Optical  Fiber 

The  basic  FDDI  standard  uses  graded-index  multi-mode  optical  fiber  with 
surface  Light  Emitting  Diodes  (LEDs)  transmitting  at  a  nominal  wavelength  of  1325 
nanometers.  This  wavelength  is  a  near  "zero-dispersion"  in  conventional  germanium- 
doped  silica  fibers.  Multi-mode  fibers  can  collect  output  from  Light  Emitting  Diodes, 
which  have  much  larger  emitting  areas,  are  less  expensive,  and  have  high  reliability.  The 
graded-index  reduces  the  mode  dispersion  of  a  multi-mode  fiber,  allowing  higher 
bandwidths.  Commercial  graded-index  fibers  attains  bandwidths  of  around  a  Gigahertz- 
Kilometer  [Ref.  6]. 

The  FDDI  standard  recommends  the  use  of  62.5/ 125  micron  (one 
thousandth  of  a  millimeter)  optical  fiber  with  minimum  required  fiber  bandwidth  is  500 
Megahertz-Kilometer  at  the  1300  nanometer  operating  wavelength  of  transmitters  and 
receivers.  At  this  wavelength,  the  attenuation  of  multi-mode  fiber  is  in  the  range  of  0.6 
to  1.0  decibel/kilometer.  The  62.5/125  micron  refers  to  the  diameter  of  the  core  and 
cladding  of  the  optical  fiber.  Alternates  multi-mode  fibers  such  as  50/125,  100/140,  or 
85/125  are  also  allowed  [Ref.  17].  The  fiber  links  in  FDDI  can  be  up  to  two  kilometers 
sq)art.  The  standard  specifies  an  instantaneous  data  transmission  rate  of  100  Megabits  per 
second,  which  is  the  absolute  upper  bound  on  the  throughput  rate  of  the  network.  The 
effective  sustained  data  rate  at  the  data  link  layer  can  be  over  95  percent  of  this  peak  rate 
[Ref.  13]. 

Single-mode  fiber  is  another  stq)  in  the  evolution  of  FDDI.  The 
maximum  distance  of  two  Kilometers  achieved  with  multi-mode  is  extended  to  60 


11 


kilometers  in  the  specifications  for  the  single-mode  fiber  added  to  the  FDDI  standards; 
however,  the  data  rate  is  maintained  at  100  Megabits  per  second.  With  larger  distances 
FDDI  can  be  an  important  backbone  high-speed  network  to  link  other  LANs. 

2.  FDDI  Standards  and  Their  Relations 

Figure  3  depicts  the  organization  of  the  FDDI  standards.  These  standards 
relate  to  layer  1  (Physical)  and  layer  2  (Data  Link)  of  the  OSI  reference  model.  The 
basic  FDDI  assumes  the  use  of  IEEE  802.2  standard,  Logical  Link  Control  (LLC), 
however  does  not  specify  this  standard.  The  Basic  FDDI  is  organized  as  follows: 

•  Physical  Layer  (PL),  which  is  divided  into  two  sublayers:  the  Physical  Medium 
Dependent  (PMD),  and  the  Physical  Layer  Protocol  (PHY). 

•  Data  Link  Layer  (DDL),  which  is  divided  into  sublayers:  the  Media  Access 
Control  (MAC),  and  the  optional  Logical  link  Control  (LLC).  Other  optional 
sublayers  are  being  processed  as  an  enhancement  to  the  approved  FDDI  standard. 

•  Station  Managemoit  (SMT),  which  conducts  a  node  level  control  necessary  to 
ensure  cooperation  with  other  nodes  on  a  ring. 

The  arrows  betweoi  the  entities  indicate  their  relations.  FDDI  describes  these 
relations  as  services  that  two  entities  must  provide  and  require  at  the  interface  betwera 
them. 

The  Physical  Layer  Medium  Dqiendent  standard  (PMD)  is  the  bottom 
sublayer  of  the  Physical  Layer.  This  sublayer  provides  all  scn/ices  necessary  to  pass 
successfully  the  serial  bit  stream  of  digital  code  from  node  to  node.  The  PMD  defines 
the  {rfiysical  medium,  drivers  and  receivers,  optical  signal  and  waveform  requirements, 
cable  plant,  connectors,  and  medium  characteristics.  This  standard  specifies  an  optical 
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multi-mode  fiber  ring  for  the  basic  FDDI  with  a  transmission  data  rate  of  100  Megabits 
per  second,  using  the  nonreturn  to  zero,  invert  on  ones  (NRZI)  4B/SB  encoding  scheme. 
The  wavelength  specified  for  data  transmission  is  132S  nanometers.  The  default  values 
for  nodes  connectivity  establish  1000  physical  links  as  basis,  a  maximum  distance 
between  adjacoit  repeaters  of  two  Kilometers,  and  200  kilometm  of  total  fiber  path 
length.  These  values  typically  correspond  to  SOO  nodes  distributed  over  100  kilometers 
of  dual  fiber  cable;  howevo’,  FDDI  can  si^Tport  larger  networks  by  increasing  the  node 
connectivity  values. 
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The  Physical  Layer  Protocol  (PHY)  defines  the  physical  layer  services  and 
addresses  the  data  encoding/decoding,  clocking,  latency,  and  data  framing.  The  PHY 
defines  the  physical  layer  services  in  terms  of  primitives  and  parameters.  These 
primitives  support  the  transfer  of  data  from  a  single  MAC  entity  to  all  MAC  entities 
contained  within  the  same  local  network  defined  by  the  medium.  The  PHY  specifies  the 
data  encoding  scheme  by  using  a  code  called  4B/SB.  This  scheme  does  encoding  four  bits 
at  time;  it  encodes  each  four  bits  of  data  into  a  symbol  with  five  cells  such  that  each  cell 
contains  a  single  signal  element  (presence  or  absence  of  light).  In  effect,  it  encodes  each 
set  of  four  bits  as  five  bits.  Thus,  the  protocol  achieves  1(X)  Megabits  per  second  with 
125  Megabaud.  The  PHY  further  encodes  the  4B/SB  using  Non  Return  to  Zero  Inverted 
(NRZI),  which  uses  differential  encoding,  which  improves  reliability  in  the  presence  of 
noise  and  distortion.  This  reliability  is  because  differential  mcoding  decodes  the  signal 
comparing  adjacent  signal  elements  rather  than  the  absolute  value  of  a  signal  element. 

The  Media  Access  Control  (MAC)  corresponds  to  the  lower  half  of  the  Data 
Link  Layer  for  the  FDDI.  The  standard  assumes  that  MAC  can  be  developed  to  operate 
unda*  the  Logical  Link  Control  (LLC)  of  the  ANSI/I^££  802  series.  It  is  the  MAC 
which  actually  specifies  the  tokra  passing  and  data  transfer  features,  and  thus  is  of 
primary  interest  in  this  thesis. 

The  Media  Access  Control  standard  presents  its  specifications  in  terms  of  the 
MAC  services,  facilities,  and  the  MAC  protocol  operation.  The  number  of  MAC  services 
dqpends  chi  the  implementation;  however,  a  minimum  set  of  sovices  shall  be  provided 
to  satisfy  the  requiremoits  of  the  Logical  Link  Control  or  any  other  higher  level  protocol 
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being  used.  The  interface  includes  facilities  for  transmitting  and  receiving  protocol  data 
units  (PDU),  and  provides  operation  status  information  for  use  by  higher-layer  error 
recovery  procedures.  The  MAC  specification  defines  the  frame  structure  and  the 
interactions  that  take  place  between  MAC  entities.  In  general,  MAC  specifies  access  to 
the  medium,  addressing,  data  checking,  fiame  format,  and  frame  content  interpretation. 

The  Station  Management  standard  (SMT)  defines  the  FDDI  station 
configurations,  the  ring  configurations,  and  specifies  the  control  required  for  proper 
op^tion  and  interoperability  of  stations  in  an  FDDI  ring.  FDDI  divides  SMT  operation 
into  three  broad  categories  [Ref.  13]:  Connection  Management  (CMT),  Ring 
Management  (RMT),  and  Operational  Management.  CMT  establishes  and  maintains  the 
physical  and  logical  topology  of  the  FDDI  network  and  manages  the  physical  layer 
resources  of  an  FDDI  node.  CMT  includes  the  protocols  for  ring  formation  and  fault 
isolation  on  the  duplex  optical  data  links  that  connects  FDDI  stations.  RMT  deals  with 
the  correctness  of  the  logical  ring  operation.  It  manages  the  MAC  layer  resources  of  a 
station.  Operational  Mmiagement  deals  with  the  management  of  the  FDDI  network  in  the 
operational  state.  These  are  multiple  stations  services  with  the  purpose  of  proper 
pperatitHi  and  interoperability  achievement. 

There  are  also  other  standards  bdng  developed  as  extensions  to  the  basic 
FDDI.  A  Single-Mode  Fiber  versicm  of  the  PMD  standard  (SMF-PMD)  will  increase  the 
loigth  of  permissible  fiber  links  from  two  to  60  Km.  This  standard  provides  an  alternate 
to  the  basic  PMD.  Another  standard  being  developed  that  provides  an  alternate  to  basic 
PMD  is  the  FDDI-to-SONET  (Synchronous  Optical  NETwork)  physical  Layer  Mapping 
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Functi(Mi  standard.  This  standard  will  provide  a  transport  for  FDDI  over  SONET 
common  carrier  facilities  [Ref.  13].  A  third  extension  to  the  basic  FDDI  is  the  Hybrid 
Ring  Control  standard  (HRC),  which  specifies  FDDI-n.  HRC  provides  multiplexing  of 
packet  and  circuit  switched  data  on  the  shared  FDDI  medium.  The  purpose  of  FDDI 
standards  is  to  ensure  interoperability  between  conforming  FDDI  implementations.  The 
implementations  shall  follow  the  guidelines  of  the  standards  functional  descriptions, 
however  these  implementations  may  employ  any  design  technique  that  is  interoperable 
[Ref.  18]. 

B.  THE  MEDIA  ACCESS  CONTROL  (MAC)  STANDARD 

The  Media  Access  Control  (MAC)  provides  deterministic  access  to  the  medium, 
address  recognition,  generation  and  verification  of  frame  check  sequences.  Its  primary 
function  is  the  delivery  of  fiames,  including  frame  insertion,  repetition,  and  removal. 
[Ref.  19] 

As  with  TFEF  802.5,  FDDI  configures  the  network  as  a  ring.  The  basic  operation 
of  the  token  is  similar  for  both  802.5  and  FDDI,  however  FDDI  employs  dual  counter¬ 
rotating  rings:  a  primary  and  a  secondary  ring.  The  secondary  ring  exists  primarily  for 
the  purpose  of  redundancy.  This  improves  reliability  on  an  FDDI  network. 

The  basic  FDDI  networic  employs  two  classes  of  services,  synchronous  service  and 
asynduonous  service.  Synchronous  service  is  for  applications  where  the  nodes  ddiver 
predictable  units  of  data  at  r^ular  intervals,  such  as  real-time  control  that  requites  access 
to  the  channel  within  a  qiedfic  time  period  [Ref.  4].  Each  node  is  allotted  a  fraction  of 
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the  total  available  FDDI  bandwidth  for  its  synchronous  service.  Asynchronous  service 
receives  lowest  priority.  This  service  is  permitted  only  after  the  station  has  finished  its 
synchronous  transmissions  and  if  the  timing  requirements  allow  the  service  execution. 

The  FDDI  MAC  also  provides  a  mechanism  that  satisfies  the  requirement  for 
dedicated  multiframe  traffic.  A  station  may  initiate  an  extended  dialogue  requiring 
substantially  all  of  the  unallocated  (asynchronous)  ring  bandwidth  by  using  a  restricted 
token.  The  initiating  station  captures  a  nonrestricted  token,  transmits  the  Hrst  frame  of 
the  dialogue  to  the  addressed  station,  and  then  issues  a  restricted  token.  The  destination 
address  station  receives  the  initial  dialogue  frame,  enters  the  restricted  mode,  and  then 
these  two  stations  may  exchange  data  ftames  and  restricted  tokens  for  the  duration  of  the 
dialogue.  Restricted  token  mode  is  terminated  upon  the  capture  of  a  restricted  token  by 
the  terminating  station.  This  station  transmits  its  final  dialogue  frame,  then  issues  a 
nonrestricted  token.  Any  station  may  transmit  synchronous  frames  upon  capture  of  either 
type  of  token.  [Ref.  19] 

The  FDDI  MAC  protocol  has  a  number  of  other  functions.  MAC  is  responsible  for 
data  integrity.  For  example,  it  ensures  the  frames  are  not  corrupted.  A  valid  frame 
criteria  defined  in  the  MAC  enforces  the  required  reliability  of  frame  reception.  Another 
responsibility  is  data  stripping.  For  example,  the  MAC  of  a  transmitting  station  is 
responsible  for  the  removal  from  the  ring  of  all  the  frames  that  it  has  place  1  on  the  ring. 
Ring  initialization,  OTor  detection  and  conection  are  also  responsibilities  of  MAC.  Ring 
initialization  ensures  the  generation  of  only  one  token.  Each  station  monitors  the  ring  for 
invalid  conditions  requiring  ring  initializadon.  Invalid  conditions  include  an  extended 
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period  of  inactivity  or  incorrect  activity.  If  an  station  detects  that  the  time  since  it  last 
saw  a  valid  token  significantly  exceeds  the  Target  Token  Rotation  Time  (TTRT),  then 
the  station  assumes  an  error  condition.  The  error  detection  and  correction  involves  the 
Claim  Token  Process,  the  Initialization  Process,  and  the  Beacon  Process.  Any  station 
detecting  the  need  for  initialization  of  the  ring  initiates  the  claim  process  by  issuing 
Claim  frames.  The  MAC  protocol  uses  this  procedure  to  negotiate  the  same  value  for  the 
Token  Rotation  Time  (TRT)  in  all  of  the  stations  on  the  ring  and  to  resolve  contention 
among  stations  attempting  to  initialize  the  ring.  The  station  that  has  won  the  claim 
process  accomplishes  the  initialization  process.  The  MAC  protocol  uses  the  beacon 
process  to  isolate  a  serious  ring  failure  such  as  a  break  on  the  ring.  [Ref.  13] 

1.  Facilities  Specification 

The  facilities  clause  of  the  FDDI  MAC  and  PHY  standards  define  the  means 
by  which  peer  entities  communicate  on  the  ring.  MAC  facilities  include  symbol  set, 
protocol  data  units  formats,  timers,  and  counts.  PHY  facilities  are  coding,  symbol  set, 
and  line  states.  As  background  for  protocol  description  and  formal  specification  presented 
in  this  thesis  it  is  relevant  to  describe  the  symbol  set,  formats  of  PDU,  timers,  and 
counts  used  by  the  MAC. 

a.  The  FDDI  Symbol  Sa 

MAC  and  PHY  operate  similarly  in  a  peer  communication,  however  they 
use  different  signal  units.  MAC  uses  a  symbol  as  an  atonuc  signaling  element  to  convey 
information;  the  PHY  oitity  uses  a  code  bit  as  the  smallest  signaling  element.  Code  bits 


are  logical  ones  and  zeros  that  represent  optical  signal  polarity  transitions  by  the  use  of 
NR21  encoding  technique.  A  symbol  is  a  group  of  five  consecutive  code  bits.  This 
sequence  is  also  called  as  code  group.  Each  code  group  provides  32  possible  bit 
combinations.  The  establishment  of  code  group  boundaries  is  a  concept  implied  in  the 
definition  of  code  group.  This  process  is  known  as  framing,  and  the  established  boundary 
is  known  as  "framing  boundary."  Table  1  shows  the  FDDI  symbol  set  mapped  to  code 
groups  (adapted  from  the  MAC  standard).  FDDI  uses  symbols  to  convey  three  types  of 
information:  line  state  symbols,  control  sequences,  and  data  quartets. 
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TABLE  1:  SYMBOL  CODING  (ADAPTED  FROM  MAC  STANDARD) 


1  Code  Croiqi 

Symbol  | 

1  Decimal 

Binary 

Name 

Assigrunent  | 

1 

•  Line  State  Symbols  | 

00 

Q 

Quiet 

04 

00100 

H 

Halt 

31 

11111 

I 

Idle 

#  Control  Sequences 

(a)  Control  Symbols: 

24 

11000 

J 

First  syinbol  of  JK  pair 

17 

10001 

K 

Second  symbol  of  JK  pair 

13 

01101 

T 

Ending  Delimiter  symbol 

1  (b)  Control  Indicators:  | 

07 

00111 

R 

Reset  Oogical  ZERO  or  OFF)  | 

25 

11001 

S 

Set  (logical  ONE  or  ON) 

#  Data  Quartets 

Hexadecimal  binary 

30 

11110 

0 

0  0000 

09 

01001 

1 

1  0001 

20 

10100 

2 

2  0010 

21 

10101 

3 

3  0011 

10 

01010 

4 

4  0100 

11 

01011 

5 

5  0101 

14 

OHIO 

6 

6  0110 

IS 

01111 

7 

7  0111 

18 

10010 

8 

8  1000 

19 

10011 

9 

9  1001 

22 

10110 

A 

A  1010 

23 

10111 

B 

B  1011 

26 

11010 

C 

C  1100 

27 

11011 

D 

D  1101 

28 

11100 

E 

E  1110 

29 

11101 

F 

F  nil 

1  •  Invalid  Code  Points  | 

01 

00001 

VorH 

These  code  points  shall  not  be 

02 

00010 

VorH 

transmitted  because  they  violate  run 

03 

00011 

V 

length  or  duty  cycle  requiranents. 

06 

00110 

V 

Stream  of  co^  points  01,  02,  08  and 

08 

01000 

VorH 

16  shall  be  intmpreted  as  Halt  s^ien 

12 

01100 

V 

detected. 

16 

10000 

VorH 
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There  are  three  line  state  symbols:  Quiet  (Q),  Halt  (H),  and  Idle  (I). 
These  symbols  are  for  use  on  the  medium  between  transmission  of  Data  Link  Layer 


(DDL)  protocol  data  units.  The  meaning  of  each  line  state  symbols  is  as  follows: 

•  Q  indicates  absence  of  activity  on  the  medium. 

•  H  indicates  a  logical  break  in  activity  on  the  medium. 

•  I  indicates  normal  condition  of  the  medium. 


Control  sequences  are  dther  control  symbols  or  control  indicator 
sequoices.  Control  symbols  are  used  to  form  the  Starting  Delimiter  (SD)  and  Biding 
Delimiter  (ED)  sequoices  of  a  Protocol  Data  Unit  (PDU).  Control  indicators  specify 
logical  conditions  associated  with  a  data  transmission  sequence  (i.e.,  a  MAC  PDU). 
Control  symbols  are  named  J,  K,  and  T.  Control  indicators  are  named  R  and  S.  The 
Encode  function  of  PHY  uses  the  symbol  sequence  "JK”  hrom  MAC  to  indicate  the 
starting  boundary  of  a  PDU.  This  starting  boundary  is  called  the  Starting  Delimiter  (SD) 
of  a  PDU.  This  symbol  pair  forms  a  uniquely  recognizable  group  of  code  bits.  The 
symbol  "T”  is  the  ending  delimiter  symbol  used  to  terminate  all  PDUs.  This  control 
symbol  shall  rqipear  in  the  Ending  Delimiter  (ED)  field  of  a  PDU.  The  ED  field  may  use 
either  one  or  two  T  symbols;  if  a  PDU  is  as  frame  then  the  ED  field  contains  only  one 
T  symbol.  In  this  case  the  T  symbol  shall  be  followed  by  the  Frame  Status  field  that  has 
a  minimum  of  three  control  indicator  symbols  (R,  S)  to  form  a  sequrace  with  even 
number  of  symbols  also  called  balanced  sequence  of  symbol  pairs.  If  a  PDU  is  a  token 
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then  no  control  indicators  are  present;  in  this  case  the  ED  field  contains  two  T  symbols. 
As  opposed  with  Starting  Limit  that  has  a  uniquely  recognizable  code  bit  sequence 
regardless  of  previously  established  framing  boundaries,  the  Ending  Delimiter  cannot  be 
recognized  as  indq)endent  of  symbol  boundaries.  Therefore,  previous  establishment  of 
frame  boundaries  is  necessary  for  proper  decoding  of  this  symbol. 

A  data  quartet  symbol  conveys  four  data  bits  of  arbitrary  data  within  a 
frame.  The  hexadecimal  digits  (0-F)  denote  the  sixteen  data  quartet  symbols.  The 
character  "n"  denotes  a  generic  element  of  this  set.  The  encoding  technique  used  by  PHY 
is  called  as  4B/SB  since  each  four  bits  of  data  are  encoded  into  a  symbol  of  five  cells, 
each  cell  contains  a  single  signal  element. 

A  violation  symbol  V  dmotes  a  condition  on  the  medium  that  does  not 
conform  to  any  other  symbol  in  the  symbol  set.  Invalid  code  points  are  formed  by  V  or 
H  symbols.  These  Code  Points  are  not  to  be  transmitted  since  a  violation  on  code  run 
loigth  and  Direct  Current  balance  requirements  will  occur. 

b.  Formats  of  Protocol  Data  Units 

FDDI  MAC  specifies  two  formats  of  PDU:  frame  and  tokra  formats. 
Frame  formats  are  variable-length  PDU  used  for  transmission  of  Data  Link  Layer 
messages.  FDDI  MAC  ctmtrols  the  sizes  of  frames  as  required  by  the  physical  layer.  The 
maximum  frame  length  is  4500  octets  or  9000  symbols.  Tokens  are  short  fixed-length 
PDU  that  allow  the  right  to  transmit  data.  Frames  and  tokras  are  structured  in  predefined 
sequoices  of  fields.  Each  field  contains  one  or  more  symbols  ordered  so  that  the  left- 
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most  symbol  is  to  be  transmitted  first,  and  is  the  most  significant  bit.  Figure  4  depicts 
the  frame  format. 


SD 

FC 

DA 

SA 

INFO 

FCS 

ED 

MM 

DB 

4n  orl2D 

4n  orl2i 

^  "  ®max 

8n 

B 

BOB 

n  1  n 

>3  S/R 

Figure  4:  The  Frame  Format 


Each  field  of  the  hrame  format  has  the  following  meaning: 


•  Preamble  (PA)  •  consists  of  1 6  or  more  Idle  symbols  to  signal  a  start  transition  for 
synchronization  of  station’s  clock. 

•  Starting  Delimiter  (SD)  -  consists  of  two  symbols  (J  and  K)  to  signal  a  start  recdve 
of  a  frame. 

•  Frame  Control  (FC)  -  consists  of  two  data  symbols.  These  two  symbols  has  the 
following  eight  bit  format:  CLFF  ZZZZ.  '^ese  bits  indicate  the  Class  (C)  of 
service,  the  Loigth  (L)  of  both  MAC  addresses  (DA  and  5A),  and  the  frame  type 
(FF  in  conjunction  wiA  the  CL  and  ZZZZ  bits). 

•  Destination  Address(DA)  -  consists  of  four  or  12  symbols  to  indicate  the 
destination  address  of  the  PDU. 

•  Source  Address  (SA)  -  consists  of  four  or  12  symbols  to  indicate  the  originator  of 
the  PDU. 

•  Information  (INFO)  -  consists  of  zero,  one,  or  more  data  symbol  pairs.  Hiese 
symbols  forms  the  contoits  of  the  IXC,  SMT,  or  MAC  message  carried  by  the 
f^e. 
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•  Frame  Check  Sequence  (FCS)  -  consists  of  eight  data  symbols.  This  field  is  used 
to  detect  errors  on  data  bits  within  the  frame  as  well  as  erroneous  addition  or 
deletion  of  bits  to  the  frame. 

•  Ending  Delimiter  (ED).  -  consists  of  one  terminate  symbol  (T)  to  indicate  a  frame 
ending.  The  field  is  necessary  to  provide  a  criteria  for  acceptance  of  a  valid  frame. 
The  ED  must  be  met  before  a  fi^e  is  accepted. 

•  Frame  Status  (FS)  -  consists  of  three  or  more  Control  Indicators  symbols  (R  and 
S)  that  follows  the  Ending  Delimiter  of  a  frame.  The  first  three  Control  Indicators 
ate  mandatory.  They  indicate  Error  Detected  (E),  Address  Recognized  (A),  and 
Frame  Copied  (C). 


c.  Timers  and  Counts 

FDDI  is  essentially  a  timed  token  rotation  protocol.  The  MAC  standard 
specifies  a  set  of  timers  and  counts  to  regulate  and  monitor  ring  operation.  Each  station 
maintains  three  timers  to  perform  the  timing  requirements  for  the  services:  the  Token 
Rotaticm  Timer  (TRT),  the  Token  Holding  Timer  (THT),  and  the  Valid-Transmission 
Timer  (TVX).  In  addition,  each  MAC  maintains  frame  counts  as  an  aid  to  monitor  the 
network  performance,  problem  determination  and  fault  location.  Implementations  may 
optionally  employ  other  count,  however  three  counts  are  mandatory:  Frame_ct,  Error_ct, 
and  Lost^Ct.  The  next  paragrsq)hs  briefly  describe  these  timers  and  counts. 

The  purpose  of  TRT  is  to  control  ring  scheduling  during  normal 
operation  and  to  detect  and  recover  from  serious  ring  errors  situations.  TRT  measures 
the  time  since  a  statitm  last  received  a  tokm  in  a  rotation  from  one  cycle  to  the  next  so 
that  it  defines  if  the  token  is  "early*  or  "late."  During  differait  phases  of  ring  operation 
the  protocd  initializes  TRT  with  different  values  whenever  it  expires.  The  number  of 
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TRT  expirations  is  important  information  to  assist  Station  Management  in  the  isolation 
of  serious  ring  errors.  A  counter  called  Late_Ct  accumulates  the  TRT  expirations. 

The  Token  Holding  Timer  (THT)  saves  a  time  value  for  a  dynamic 
bandwidth  sharing  or  asynchronous  service.  This  timer  is  initialized  with  the  current 
value  of  TRT  when  a  station  captures  the  token.  During  the  asynchronous  service,  THT 
is  running  to  control  transmission  of  asynchronous  frames.  A  MAC  may  initiate  a 
transmission  of  these  frames  if  timer  THT  has  not  expired.  In  addition,  a  station  shall 
release  the  token  before  its  allocated  THT  expires. 

The  Valid'Transmission  Timer  (TVX)  assists  Station  Management  to 
recover  from  transient  ring  error  situations.  The  MAC  standard  describes  the  derivations 
for  a  timeout  TVX  value  called  TVX_value.  Once  TVX  expires  it  remains  in  this 
condition  until  reset  by  the  Receiver. 

Frame_Ct  is  the  count  of  all  frames  received.  This  count  is  incremented 
whenever  the  terminate  symbol  (T)  of  a  frame  Ending  Delimiter  (ED)  field  is  received. 

ErTor_Ct  is  the  count  of  error  ihunes.  This  count  is  incremented  if  this 
MAC  detects  a  frame  error  that  no  previous  MAC  has  detected.  This  condition  holds  true 
when  the  Receiver  sets  an  error  flag  for  the  arrived  frame  received  with  the  Frame  Status 
fleld  blowing  the  Error  Detected  indicator  not  set  (E  ^  S);  otherwise,  no  error  flame 
is  counted  by  this  MAC  since  the  error  have  been  already  counted  by  other  MAC. 

Lost_Ct  is  the  count  of  all  instances  in  which  MAC  is  in  the  process  of 
receiving  a  PDU  and  an  error  is  detected  that  prevents  PDU  reception.  In  these  cases, 
MAC  increments  Lost_Ct  and  strips  the  rest  of  the  PDU  from  the  ring,  transmitting  idle 
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symbols.  Whoi  remnants  of  PDU  are  received  Lost_Ct  is  not  incremented  because  they 
are  followed  by  Idle  symbols.  The  specification  presented  in  this  thesis  shows  precisely 
these  instances  for  each  incoming  sequences  that  form  the  PDU.  For  example,  whenever 
a  format  error  occurs  on  the  Starting  Delimiter  of  a  PDU  the  Receiver  sends  a  FO_£nor 
to  the  Transmitter,  increments  the  Lost_Ct,  and  enters  the  AWAIT  SD  state  for  a  new 
PDU.  Then,  the  Transmitter  begins  to  transmit  Idle  symbols  stripping  the  PDU  from  the 
ring.  The  specification  covers  similar  operation  for  all  PDU  field  sequences  which  comes 
with  a  format  error  or  whenever  a  PH_invalid  signal  is  received  from  PHY. 

2.  Operation 

This  subsection  briefly  discusses  several  characteristics  of  the  protocol 
operation,  which  are  of  interest  for  the  formal  specification.  The  timed-toten  mechanism, 
ring  scheduling,  frame  and  token  transmission,  and  frame  stripping  are  discussed. 

n.  FDDI  Ilmed-Token  Access  Method 

By  passing  a  token  around  the  ring,  FDDI  controls  the  opportunity  that 
each  station  will  have  to  transmit  a  frame  or  a  sequence  of  frames.  A  token  is  a  specific 
bit  sequence  that  circulates  among  the  nodes  on  the  ring,  giving  transmit  permission  to 
any  station  that  wants  to  transmit  its  data.  Once  a  station  "captures"  a  token,  its  frames 
may  be  transmitted.  However,  the  access  to  the  network  and  scheduling  is  also  controlled 
by  timers.  The  next  paragrsq)hs  provides  tiie  details  of  the  timing  rules  for  the  ring 
scheduling  process  of  a  FDDI  network. 
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A  tey  parameter  set  by  the  managers  of  FDDI  networks  is  the  Target 
Token  Rotation  Time  (TTRT)  [Ref.  2].  This  is  a  value  negotiated  between  all  stations 
MAC  during  ring  initialization  via  the  Claim  Token  process.  As  part  of  the  Claim  Token 
process  at  the  time  of  ring  initialization,  each  MAC  station  uses  a  requested  TTRT  value 
(T_Req)  to  negotiate  for  the  lowest  operative  value  of  TTRT  (T_Opr).  This  value  is 
required  to  be  in  the  range  of  Token  Rotation  Timer  (TRT),  which  is  established  for  all 
stations  as  the  closed  interval  from  a  minimum  to  a  maximum  TTRT  value  to  be 
requested  (T_Min  and  T_Max).  As  a  result  of  this  negotiation,  the  lowest  value  of  T_Req 
becomes  the  negotiated  TTRT  value  (T_Neg)  at  the  Receiver  of  each  station.  The  MAC 
winning  Claim  Tokm  station  then  sets  the  operative  TTRT  value  (T_Opr)  to  the 
negotiated  TTRT  value  (T_Neg). 

Tokens  may  be  "early"  or  "late."  A  token  which  arrives  before  TRT  reaches 
TTRT  is  an  "early"  token,  otherwise  is  a  "late"  token.  TRT  is  reset  to  T_Opr  each  time 
an  early  token  arrives.  An  early  token  may  be  used  for  both  classes  of  services 
synchronous  or  asynchronous,  whereas  a  late  token  may  be  used  only  for  synchronous 
service. 

The  FDDI  protocol  guarantees  an  average  TRT  not  greater  than  TTRT, 
and  a  maximum  TRT  not  greater  than  twice  TTRT.  Johnson  in  [Ref.  3]  proved  that  the 
timing  requirements  of  this  protocol  are  satisfied. 

Figure  S  illustrates  how  T_Opr  for  the  ring  is  obtained  during  ring 
initialization.  This  figure  shows  a  timing  chart  for  n  FDDI  stations.  The  station  number 
two  is  iht  winning  Claim  Token  station  since  its  T_Req  is  the  lowest  of  all  requested 
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Figure  5:  Derivation  of  T_C>pr  During  Ring  Initialization 


TTRT  values  that  fall  in  the  range  of  TRT.  Note  that  if  a  T_Opr  falls  outside  the  range 
of  TRT  then  a  station  is  unable  to  operate  correctly  on  the  ring  (stations  J  and  K). 

The  Token  Rotation  Tima-  (TRT),  the  Token  Holding  Tima:,  the 
station’s  synchrcmous  bandwidth  allocation,  and  the  counter  Late_Ct  govern  the  amount 
of  time  that  a  staticm  may  hold  the  token  and  transmit  frames  [Ref.  4].  The  timed-tokoi 
rules  of  FDDI  are  summarized  as  follows; 


•  If  Late_Ct  =  0  (token  early),  that  the  Transmitter  places  the  current  value  of  TRT 
into  THT,  and  resets  TRT  to  T_Opr.  This  is  rq)resented  in  the  formal  specirication 
as  THT  *-  TRT;  and  TRT  *-  T_Opr;  both  synchronous  and  asynchronous  frames 
may  be  transmitted. 
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•  If  Late_Ct  >  0  (token  late),  the  value  "expired"  is  placed  into  THT,  and  Late_Ct 
is  clea^  (THT  ♦-  expired;  Late_Ct  *-  0;).  In  this  case,  TRT  is  not  reset  to  T_5pr 
and  only  synchronous  frames  may  be  transmitted. 

•  During  synchronous  transmissions  only  TRT  is  running.  During  asynchronous 
transmissions  both  TRT  and  THT  are  running. 

•  No  frames  are  allowed  to  be  transmitted  after  expiration  of  the  station’s  TRT.  The 
loigth  of  time  an  individual  station  may  transmit  synchronous  frames  is  bounded 
above  by  its  synchronous  bandwidth  allocation.  The  THT  limits  the  time  for 
asynchronous  frames. 


In  the  formal  specifrcation  the  station  MAC  Transmitter  is  responsible 
to  carry  out  the  timing  operations.  The  model  allows  the  representation  of  ring 
scheduling  in  the  FDDI  network.  The  MAC  Transmitter  State  Diagram  and  the 
Transition  Table  show  the  representation  of  these  rules. 

b.  Fnmt  and  token  tmnsmis^n 

Upon  a  request  for  Service  Data  Unit  (SDU)  transmission,  MAC 
constructs  the  Protocol  Data  Unit  (PDU)  or  frame  from  the  SDU  by  placing  the  SDU  in 
the  INFO  field  of  the  frame.  The  SDU  remains  queued  by  the  requested  entity  awaiting 
for  the  receipt  of  a  token.  After  the  token  is  captured  the  station’s  MAC  transmits  its 
queued  frames  according  to  the  rules  of  the  token  holding.  [Ref.  19] 

After  the  token  holding  station  completes  the  transmission  of  frame  or 
frames,  the  MAC  immediately  issues  a  new  token.  The  standard  leaves  as  optional  the 
implemoitation  of  a  MAC  which  may  wait  to  see  one  or  more  frames  return  before 
issuing  the  token. 
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c.  Gripping 

The  stripping  method  of  FDDI  defines  the  frame  originator  as  the  station 
responsible  for  frame  removal  from  the  ring.  Since  the  decision  to  strip  a  frame  is 
normally  based  upcm  the  recognition  of  the  MAC’S  address  in  the  SA  field,  which  cannot 
occur  until  after  the  initial  part  of  the  frame  has  already  been  repeated,  some  remnants 
of  riames  continue  to  circulate  on  the  ring.  These  remnants  consists  most  of  the  PA,  SD, 
FC,  DA,  SA,  and  six  symbols  after  the  SA  field,  followed  by  idle  symbols.  This 
truncated  frame  will  not  cause  problems  to  the  ring  because  all  other  stations  will 
recognized  these  sequences  of  symbols  as  a  remnant  since  they  are  followed  by  idle 
symbols  and  no  terminate  symbol  ”T"  will  be  received.  With  the  formal  specification 
presented  in  this  thesis  the  MAC  Receiver  establishes  a  check  for  remnants  in  every  field 
of  the  incoming  PDU,  which  enhances  the  protocol  error  checking  specification.  Also, 
dinner  m  will  show  that  the  stripping  method  in  the  normal  operation  of  the  improved 
protocol  is  changed  such  that  the  Destination  Address  (DA)  station  is  responsible  for  the 
removal  of  Logical  Link  Control  (LLC)  or  Station  Managemmt  (SMT)  frames  from  the 
ring.  This  leaves  less  remnants  fields  of  frames  on  the  ring  since  the  DA  comes  first  in 
a  PDU  sequence  of  fields. 

3.  Service  Specification 

The  service  specification  defines  a  set  of  functions  that  one  layer  or  sublayer 
entity  provides  to  its  users  above  or  to  managemmt  ratifies.  These  functions  are  defined 
in  terms  of  primitives  and  parameters.  The  primitives  describe  the  opraations  carried 
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through  the  interface  in  which  the  service  is  provided.  The  parameters  are  associated  with 
the  primitives  and  the  execution  of  a  service  primitive  depends  on  the  exchange  of 
parameters  between  two  entities.  The  services  execution  of  the  protocol  observes  a  strict 
hierarchy  on  the  sequence  of  operations.  At  any  given  moment  the  allowed  primitive  and 
parameter  values  depend  on  preceding  history  of  operations.  The  model  for  protocol 
specification  used  in  this  thesis  is  suitable  to  specify  the  FDDI  protocol  because  it 
represents  precisely  this  sequence  of  operations.  Although  the  standards  specify  clauses 
with  mandatory  services  they  also  specify  optional  services.  Furthermore,  the  standards 
accq>t  as  equally  valid  any  implementation  technique  that  causes  the  same  external 
behavior  of  the  protocol.  Figure  6  shows  the  set  of  services  that  MAC  supplies  to  the 
local  LLC  entity  and  SMT  entity  and  also  the  services  required  by  MAC  from  the  local 
PHY  entity.  The  next  paragraphs  describe  the  contents  of  some  primitives  to  illustrate 
the  service  specification  provided  and  required  by  FDDI  MAC  standard. 

By  using  a  set  of  fixed-length  symbols,  peer  MAC  entities  communicate  on 
the  ring.  All  protocol  data  units  generated  by  peer  Data  Link  Layer  oitities  are  matched 
pairs  of  symbols.  However,  each  symbol  is  sent  across  the  Physical  layer  sequentially. 
On  the  transmitting  station,  MAC  conveys  information  to  local  PHY  by  a  continuous 
sequence  of  symbols  via  the  defined  primitives.  In  a  MAC-PHY  transfer  of  data,  a 
PH_DATA.request  primitive  is  used  and  the  parameter  PH_Request(symbol)  is  sent  to 
PHY  whenevCT  MAC  has  a  symbol  to  output  as  shown  in  Figure  7.  Upon  receipt  of  this 
primitive  the  PHY  entity  performs  the  ^coding  and  transmits  the  symboL  For  every 
PH_Request  received  from  MAC,  PHY  returns  a  PH^confirmation  to  provide  a 
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synchronization  of  the  MAC  data  output  with  the  data  rate  of  the  medium  and  to  indicate 
its  readiness  to  accept  another  symbol.  On  the  receiving  station,  a  PH_DATA.indication 
primitive  is  used  to  define  the  transfer  of  data  from  PHY  to  MAC.  This  indication  occurs 
whenever  PHY  decodes  a  symbol.  Also,  the  receiving  MAC  shall  only  recognize  the 
incoming  PDU  as  matched  pairs  of  symbols. 


PHY,  which  translates  them  into  bits  and  then  transmits  the  bits  as  optical  signals. 


SM_MA_CONTROL.request  is  a  primitive  used  by  SMT  to  control  the 
operation  of  MAC.  Figure  8  illustrates  this  service  primitive  at  the  interface  MAC/SMT 
with  a  table  that  contains  the  parameters  and  its  associated  values. 
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SiyLMA_CONTROLraquMt(oontrol_aclk)n,  inacJraine_inlonnalion,  requestecLstatus) 


contioLactian 

iDac_fraine_iiifonnation 

requested  status 

1.  aendLjnac,,fiiines 

2.  xeseOnac 

3.  coian4_nuic_recovefy 

4.  tewL^tame.cotnitas 

5.  pceMiit_atatus 

6.  ooottoLMAJ>ATA_reqae6t 

7.  contEoLMAJDATAJiidicatiaa 

indicates: 

DA  INFO 

indicates: 

Rame-Ct,  Eoor.Ct, 
Lost_Ct,  TVX,  TRT, 
TTRT.ILFIag, 
cnneut  Receive  State 
Machine, 

current  Transmit  State 
Machine. 

Figure  8:  The  SM_MA_CONTROL.rcquest  service  primitive 

SMT  generates  this  primitive  to  cause  MAC  to  take  the  specified  control 
acti(Mi.  For  example,  if  the  control  actimi  is  ieset_mac,  then  MAC  generates  the 
MAC_Reset  signal.  This  signal  will  be  an  cabling  predicate  for  transitions  to  occur  in 
both  MAC  Receiver  and  Transmitter.  The  formal  specification  presented  in  this  the^ 
will  show  these  transitions  in  the  state  diagrams  and  will  describe  them  in  the  transition 
tables. 

As  a  response  to  SM_MA_CONTROL.iequest(control_action  = 
present^status)  MAC  provides  the  SM_MAJSTATUS. indication  service  primitive  to 
SMT.  This  primitive  contains  a  status_rq)ort  parameter,  shown  in  Figure  9.  The  FDDI 
standard  specifies  some  of  the  status_rqx}rt  parametm  as  optional.  The  work  presoited 
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SM_MA_STATUS.Indlcation(status.report) 


sUtus_repoft 

1.  Receipt  of  a  frame  with  disdnct  zqxxt  ot 

(a)  for  frames  -  My.Oaiin,  lOjhet.Claim, 
LowaiQaim,  My_beac<^  Odier  Beacon; 

(b) *  foe  LLC  or  SMT  frames  -  My J>AJJjC_or_SMT, 
0&er_PA^JJLC_or_SMr; 

2.  EqiiiatiaQ  of:  TVX.  IRT  and  late.ct  *  0; 

3.  Reedpt  of:  m^frivalid.  MAC_ie8et; 

4.  Overflow  of  a  counter; 

5.  Ring_Opentioiial;  and 

6.  Odier  conditons  q)edfied  in  MAC  FDDI  standard. 

(*)  Not  inclnded  in  die  original  FDDI.  Added  in  the 
foemal  ^tedficatko. 


Figure  9:  The  SM_MA_STATUS.indication  service  primitive 


in  the  Chapter  IV  of  this  thesis  requires  a  more  detailed  analysis  of  the  actions  taken  by 
the  MAC  state  machines.  Additional  variables  are  included  in  the  fomud  specification. 


C.  DESCRIPTION  OF  THE  EXISTING  FORMAL  MODEL  "SYSTEMS  OF 

COMMUNICATING  MACHINES" 

This  section  describes  the  modd  system  of  communicating  machines.  This  model 
was  designed  as  a  method  for  the  formal  description  and  verification  of  communication 
protocols  [Ref.  8].  It  has  been  used  in  the  specification  of  local  area  network  protocols 
such  as  CSMA/CD  and  token  ring  [Ref.  10].  The  model  description  given  below  is  found 
in  [Ref.  9]. 

A  system  of  communicating  machines  is  an  ordered  pair  C  ~  (M,V),  where 
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M  =  {ntiMi . w*,} 


is  a  finite  set  of  machines,  and 


y  =  {v,.V2....,v*} 

is  a  finite  set  of  shared  variables,  with  two  designated  subsets  and  Wi  specified 
for  each  machine  m,.  The  subset  R,  of  V  is  called  the  set  of  read  access  variables 
for  machine  m„  and  the  subset  Wf  the  set  of  write  access  variables  for  mi.  The 
integers  n  and  it  are  the  number  of  elemoits  (machines  and  variables)  in  sets  M  and 
V. 


Each  machine  m,  €  Af  is  defined  by  a  tuple  (Si,SoJLi,Nt,Ti),  where 
(1)  Si  is  a  finite  set  of  states; 

So  6  5,  is  a  designated  state  called  the  initial  state  of  m^; 

(3)  Li  is  a  finite  set  of  local  variables; 

(4)  Ni  is  a  finite  set  of  transitions  names.  Associated  with  each  name  is  a  unique 
triple  where  p  is  an  enabling  predicate  on  the  variables  of  L,  U  Ri,  and  a  is 
an  action  on  the  variables  of  L,  U  It,  U  W,.  Specifically,  an  action  is  a  partial 
function 


a:  LiXRi-*Li'X.  W, 


from  the  values  contained  in  the  local  variables  and  read  access  variables  to  the 
values  of  the  local  variables  and  write  access  variables. 

(S)  Ti'.  St  X  Ni~*  Si  is  a  transition  function  ,  which  is  a  partial  function  fiom  the 
states  and  names  of  m,  to  the  states  of  n^. 

Machines  model  the  ratities,  which  in  a  protocol  system  are  processes  and 
channels.  The  shared  variables  are  the  means  of  communication  between  the 
machines.  Intuitively,  Rt  and  W,  are  the  subsets  of  V  to  which  m,  read  and  vmte 
access,  reqwctively.  A  machine  is  allowed  to  make  a  transition  firom  one  state  to 
another  when  the  predicate  associated  with  the  name  for  that  transition  is  true. 
Upon  taking  the  transition,  the  action  associated  with  that  name  is  executed.  The 
actions  changes  the  values  of  local  and/or  shared  variables,  thus  allowing  other 
predicates  to  become  true. 

Let  r(s„n)  «  5^  be  a  transition  which  is  defined  on  machine  m,.  (That  is,  r  is  the 
edge  pointing  from  state  s,  to  state  s^.  Transition  r  is  enabled  if  the  enabling 
predicate  p,  associated  wiA  the  name  n,  is  true,  transition  r  may  be  executed 
wtoiever  m,  is  in  state  Si  and  the  predicate  p  is  true  (enabled).  The  execution  of 
r  is  an  atomic  acticm,  in  which  both  the  state  change  an  the  action  a  associated 
with  n  occur  simultaneously. 
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The  sets  of  local  and  shared  variables  specify  a  name  and  a  range  for  each.  In 
most  cases,  the  range  will  be  a  finite  or  countable  set  of  values.  For  proper 
operation,  the  initial  values  of  some  or  all  of  the  variables  should  be  specified. 

D.  PREVIOUS  WORK  ON  IMPROVEMENT  OF  EDDI 

1.  Suggestions  on  Improvement  of  FDDI 

This  thesis  continues  the  work  on  improvement  of  FDDI  documented  in  [Ref. 
11].  In  that  paper,  Lundy  makes  the  observations  of  little  use  of  the  secondary  ring  and 
excessive  fiame  propagation  on  the  primary  ring  and  he  presents  alternative  transmission 
procedures  that  can  lead  to  a  network  throughput  of  three  to  four  times  of  the  standard. 
This  thesis  tal»s  the  suggested  procedures  for  transmission  of  frames  that  raises  the  ideal 
upper  bound  to  300  Megabits  per  second  U)  develop  the  improved  protocol  and  provide 
its  formal  specification.  This  subsection  will  review  this  previous  work  with  additional 
comments. 

The  suggested  alternative  transmission  procedure  attempts  to  increase 
parallelism,  decrease  unnecessary  frame  pixipagation,  and  make  maximum  utilization  of 
all  available  fiber.  The  basic  Timed-Token  access  method  of  FDDI  is  not  changed.  The 
goal  is  to  maximize  the  utilization  of  both  tings  by  the  Token  Holding  Station  (THS),  and 
allow  other  stations  to  use  an  available  segmrat  of  the  ring  concurrently  with  the  THS. 
The  nmct  paragn^hs  describe  this  procedure  with  illustrations. 

Two  main  changes  are  proposed  to  improve  the  throughput  in  the  FDDI 
protocol:  coircurrent  access,  and  simultaneous  transmission  on  the  dual  ding.  The  first 
change  allows  an  additional  frame  to  be  transmitted  in  parallel  on  the  same  ring  with  the 
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single  frame  allowed  by  the  standard  token  ring  protocol.  The  second  change  allows  a 
station  in  possession  of  the  token  to  transmit  on  both  rings,  in  opposite  directions, 
simultaneously.  The  first  procedure  is  suggested  as  follows: 


•  Frames  transmitted  from  station  i  to  station  j  are  removed  from  the  ring  by  station 
J  rather  than  propagating  around  the  ring.  The  frame  is  sent  on  the  ring  1,  which 
has  the  shortest  dstance  from  i  to  J  (Figure  10). 


Figure  10:  Stq>  1:  frame  transmitted  from  station  i  to  station  j  and  removed  by  J 


•  The  acknowledgment  from  i  to  j  is  sent  as  a  short  message  on  the  opposite  ring, 
(ring  2)  also  cm  the  shortest  path  (Figure  11). 

•  The  remainder  of  the  ring  may  now  be  used  for  transmission  of  another  message 
in  parallel  with  i’s  message.  Station  i  passes  a  "subtoken"  to  the  next  station  i0er 
staticm y,  which  ^recifies  the  first  and  ^  last  stations  on  the  "opoi"  segment  of  the 
ring.  The  subtoto  is  included  as  part  of  header  of  the  frame  sent  to  statioii  y, 
which  transmits  it  (the  subtokm  field  only)  (m  to  station y+i. 


The  subtoken  gives  the  right  to  only  one  station  to  transmit  on  the  unused 
portion  of  the  ring.  If  stationy +i  has  no  messages  for  any  station  on  the  s^moit, 
the  subtoken  is  passed  on  to  tte  next  station.  This  is  repeated  until  dther  one  frame 
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"subtokm”  downstream  on  the  freed  ring  segment. 

is  transmitted  on  the  segment,  or  the  subtoken  dies  at  the  last  station. 

The  length  of  the  frame  sent  on  the  "subtoken  segment"  must  be  limited  so  that 
transmission  will  complete  before  station  i  finishes  transmission  to  j  and  issues  the 
next  subtoken.  The  length  should  be  2d  most  the  length  of  the  frame  sent  by  the 
station  with  the  main  token. 


The  sectmd  change  from  the  transmitting  protocol  is  to  allow  a  station  in 
possession  of  the  tokm  to  transmit  cm  both  rings,  in  opposite  directions, 
simultaneously  (if  it  has  mote  than  one  hraine  to  transmit).  This  implies  that  each 
station  must  keep  two  queues  for  transmission,  one  for  each  ring.  To  avoid 
collisions  between  frames  the  ring  is  partitioned  by  the  destination  address  station 
(Figure  12). 

One  of  the  main  problems  that  occur  with  full  dual  ring  operations  is  the 
issue  of  distributing  the  load  onto  the  two  available  rings.  Lundy  analyzes  two  criteria 
for  queuing  up  the  frames  in  each  ring.  The  shortest  path  and  the  load  balanced  among 
the  queues. 
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The  shortest  path  criteria  would  avoid  collisions,  however  it  is  possible  that  one 
queue  would  be  longer  than  the  other,  so  that  parallelism  and  thus  throughput 
would  not  be  maximized. 

The  other  criteria,  which  the  author  believes  to  be  preferred,  is  to  keep  the  two 
queues  balanced.  This  is  possible  to  do  without  collisions  also;  however  it  could 
become  necessary  to  move  frames  from  one  queue  to  the  other,  to  avoid  collisions 
and  keep  the  two  queues  in  balance.  [Ref.  11] 

The  criteria  chosen  to  distribute  the  load  in  the  protocol  speciried  in  this 
thesis  is  the  load  balanced  queue.  In  addition  to  these  previous  observations,  the  shortest 
path  is  somewhat  efficient  for  the  simultaneous  transmissions  of  the  tokmi  holding  station 
in  an  ideal  situation  of  matched  queued  load  for  both  halves  of  the  ring;  however,  for  the 
transmissions  of  the  subtoken  holding  station  the  shortest  path  criteria  is  clearly 
undesirable.  If  a  subtoken  holding  statitm  wishes  to  srad  its  frames  on  the  subtokra 
segment  which  is  greater  than  the  (me  half  of  the  total  ring  path  then  the  shortest  path 
criteria  cannot  be  applied  to  this  station.  Furthermore,  if  different  criteria  for  distributing 
the  load  in  the  token  and  subtoken  holding  staticms  is  used,  then  the  protocol  overhead 
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may  substantially  be  increased.  Therefore,  it  is  assumed  a  load  balancing  algorithm 
applied  above  the  MAC  layer  to  maximize  the  protocol  efficiency. 

This  previous  work  forms  the  basis  for  the  development  of  a  more  detailed 
protocol  MAC  structure  presented  in  Chapter  m  and  its  formal  specification  in  Chapter 
IV.  The  FDDI  is  a  complex  protocol  and  changes  of  this  nature  open  several  important 
questions  that  need  to  be  carefully  analyzed.  One  of  the  questions  is  how  to  guarantee 
the  required  reconfiguration  capability  of  the  network  on  a  dual  ring  operation?  Another 
question  is  how  the  initialization  process  will  work  in  the  proposed  partitioned  ring 
design.  Also,  it  was  stated  that  the  dual  ring  of  trees  topology  of  FDDI  offers  the 
flexibility  and  availability  to  meet  many  requirements.  With  the  improved  protocol  is  it 
possible  to  maintain  these  similar  features  on  a  network?  These  and  other  questions  are 
discussed  in  subsequent  topics  covered  in  the  thesis. 

2.  Other  Woili  on  Improvement  of  FDDI 

The  increasing  need  for  high  speed  data  rates  in  Local  Area  Networks  has 
lead  to  much  work  on  improvemoit  of  token  ring  architectures  including  FDDI. 

In  [Ref.  1]  Cidon  and  Ofek  explain  Metaring,  a  network  that  uses  a  full- 
duplex  ring  with  spadal  reuse  and  concurrait  access  to  achieve  higher  throughput  rates. 
This  network  employs  two  basic  modes  of  operation:  buffer  insertion  for  variable  sizes 
PDUs  and  a  slotted  ring  for  fbced  PDU. 
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Th^  are  similarities  and  differences  between  Metaring  and  the  improved 
protocol  presented  in  this  thesis.  Table  2  presents  an  overall  summary  of  points  in 
common  and  contrasts  between  these  two  protocols. 


TABLE  2:  SIMILARrnES  AND  DIFFERENCES  BETWEEN  METARING  AND  THE 
IMPROVED  FDDI  PROTOCOL 


1  Metering 

Improved  FDDI  | 

1  #  To  in^rove  throughput  | 

Uses  both  rings  for  concurrent  access  and 
diqoint  ring  partitions  for  simultaneous 
transmissions. 

Four  nodes  transmitting  at  the  same  time  in 
each  direction  on  both  rings. 

Maximum  throughput:  800  Mbps 

Uses  both  rings  for  concurrent  access  and 
disjoint  ting  partitions  for  simultaneous 
transmissions. 

Two  nodes  transmitting  at  the  same  time.  The 
timed<tokeo  node  transmitting  in  each  directicm 
on  both  rings;  and  foe  subtoAeo  node 
transmitting  in  either  one  or  other  direction 
within  its  segment. 

Maximum  throughput:  300  Mbps 

1  #  Distributing  traffic  across  the  two  rings  and  stripping  method  | 

(a)  Shortest  path;  and 

(b)  Frames  removed  by  Destination  Address. 

(a)  Load  balancing  algorithm;  and 

(b)  Frames  removed  by  Destirutim  Address  in 
normal  c^ieration  and  removed  by  Source 

Address  in  "wrap  condition.* 

1  •  Fairness  | 

Use  of  single  control  message  rotating  in  the 
apposite  directioo  to  ttie  data  traffic  that  it 
regulates. 

Uae  foe  same  mechanism  of  FDDI,  the  timed- 
token  access  method;  which  has  been  proven  to 
be  foir  and  deterministic. 

1 _ •Access  control  to  the  physical  medium _ I 

Two  access  modes: 

(a)  Buffer  insertiao  for  PDU  of  variable  size; 
arid 

(b)  Slotted  ring  for  fixed  PDU. 

Timed-token  controlled  concurrent  access  which 
mnploys: 

(a)  One  main  Token  for  foe  two  s^ments  on 
both  rings  controlling  simultaneous 
transmissions;  and 

(b)  One  subloken  on  foe  third  segment  of  the 
ring  controlled  by  the  uAen  holding  station  for 
transmissioos  within  this  s^ment;  thus,  this 
access  method  allows  concurrent  transmisrions 
on  diqoint  aqpnents  of  the  ring. 

•  Ring  scheduling  and  priorities 
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1  Allows  both  classes  of  service:  synchranous  and 

1  aiqnclircMKMis;  and 

1  Allows  priorities. 

Allows  both  classes  of  service;  synchronous  and 
asynchronous;  and 

Allows  priorities. 

1  #  Addressing  | 

1  Arranged  in  an  increasing  order  (l..n) 

Same  as  in  FDDI  | 

1  •  Problems  of  access  control  || 

(a)  May  suffer  from  starvation  -  solutions  are 
presented 

The  timed-Udcen  crmtrolled  concurrent  access 
avoids  the  problem  of  starvation  since  the  three 
segments  of  the  ring  used  for  concurrent 
tnmsmissi<His  are  logical  disjoint  parts  for  ring 
access.  There  are  only  two  transmitting  nodes 
at  a  time:  the  token  and  the  subtoken  holding 
station.  The  token  holding  station  controls  the 
duratimi  of  the  subtcdcen. 

(b)  Bandwidth  reservation  -  problem  of  how  to 
guarantee  delay  to  some  of  bandwidth,  vtdiile 
still  allowing  asynchronous  distributed  access. 

1  Solution  discussed. 

No  bandwidth  reservation  problem.  Uses  the 
same  mechanism  for  service  assignment 
employed  in  FDDI.  First,  allocates  synchronous 
bandwidth,  then  asynchronous. 

1  (c)  Priority  -  the  distributed  nature  of  the  access 
is  not  allowing  the  iii4>lementation  of  a  priority 
access  scheme.  Solution  discussed. 

No  priority  problem. 

Same  priority  scheme  used  in  FDDI. 

(d)  Delay  bounds  -  problem  associated  with 
buffer  insertion  architecture. 

Same  delay  of  FDDI. 

One  of  the  key  characteristics  of  FDDI  is  its  reliability  feature  embedded  in 
the  dual  ring  architecture.  Although  the  improved  protocol  makes  use  of  both  rings 
during  normal  operation  and  uses  the  destinatimi  address  to  remove  a  frame,  when  a  link 
or  node  fails  the  protocol  switches  the  frame  stripping  mechanism  and  works  as  in  the 
original  FDDI  using  only  one  path.  Therefore,  this  is  one  of  the  main  advantages  of  this 
protocol.  The  improvement  achieved  in  utilizatimi  does  not  degenerate  the  reliability 
frinctitm  of  FDDI. 

In  [Ref.  16]  Strcriil  briefly  discusses  the  variety  of  choices  on  using  FDDFs 
dual  ring.  Amrnig  those  choices,  the  protocol  developed  in  this  thesis  flts  in  the  category 
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of  using  the  second  ring  for  traffic  in  normal  citation.  However,  by  design  decision, 
the  MAC  structure  of  this  protocol  differs  from  the  current  structures  of  MAC  used  in 
the  original  FDDI;  consequently,  diffemit  analysis  can  be  done.  Unlike  the  suggestion 
for  the  use  of  both  rings  employing  dual  MAC  stations  to  potentially  achieve  a  bandwidth 
of  200  Megabits  per  second,  this  thesis  developed  a  protocol  that  uses  a  single  MAC  to 
control  simultaneous  access  to  both  rings.  This  single  MAC  structure  is  presented  in 
Chaq;)ter  m.  Chapter  m  will  also  show  that  with  the  use  of  a  single  MAC  controlling  the 
operation  of  both  rings  this  protocol  othances  the  end-end  connectivity  through  ring 
configuration  changes. 

Other  work  on  improvement  of  token  ring  networks  have  appeared  on  the 
literature.  In  [Ref.  5]  Kamal  proposes  the  use  of  multiple  tokens  to  circumvent  the 
problem  of  excessive  delay  under  a  very  light  network  load.  Again,  among  other 
differences,  this  multiple  token  network  differs  from  the  protocol  proposed  in  this  thesis 
primarily  in  the  medium  access  control  method.  In  [Ref.  IS]  Siegel  analyzes  hardware 
and  software  functions  for  a  dual  ring  operation  in  FDDI.  An  architecture  for  an 
enhanced  FDDI  statimi  for  traffic  acceptance  and  distribution  is  presented. 
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in.  THE  IMPROVED  FDDI  PROTOCOL 


This  chapter  describes  the  improved  FDDI  protocol.  Section  A  introduces  the 
improved  FDDI  MAC/PHY  structure,  the  changes  needed  in  the  original  MAC,  and  the 
new  protocol  data  units  formats.  In  section  B,  the  mechanism  of  access  control  which 
enhances  ring  utilization  is  presented. 

A.  PROTOCOL  DESCRIPTION 

Although  the  protocol  described  in  this  thesis  differs  from  the  original  FDDI  in  the 
utilization  of  the  medium,  many  other  characteristics  of  operation  are  the  same  in  both 
protocols.  This  includes  the  timed-token  access  method.  Stations  wait  for  a  passing  tokm 
to  transmit  their  data.  They  agree  in  a  target  time  for  a  token  rotation.  The  timers  TRT 
and  THT  and  the  counters  work  in  the  same  fashion.  The  processes  for  claiming  a  token, 
ring  initialization,  and  beacon  remain  unchanged.  The  Ring  scheduling  for  the  improved 
protocol  supports  both  classes  of  service  as  in  the  original  FDDI.  In  fact,  the  key 
difference  between  the  two  protocols  is  the  use  of  a  second  access  control  Protocol  Data 
Unit,  called  "subtoken",  which  gives  the  right  to  another  station  to  transmit  concurrently 
with  the  timed-token  station,  potentially  improving  ring  utilization.  However,  the 
employment  of  this  special  PDU  in  the  improved  protocol  is  controlled  by  the  MAC 
station  that  is  holding  the  main  token;  the  parallel  access  to  the  medium  granted  by  the 
subtoken  does  not  interfere  with  the  access  given  by  the  main  token.  In  addition,  this 
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protocol  also  uses  the  second  ring  to  carry  out  simultaneous  transmission  increasing  the 
network  throughput  to  a  maximum  of  300  Megabits  per  second. 

1.  The  Improved  FDDI MAC/FHY  Organization 

To  achieve  the  high  performance  with  simultaneous  use  of  both  rings  this 
protocol  uses  an  specific  structure  for  the  trunk  ring  MAC/PHY  local  entities.  Figure  13 
depicts  this  structure.  This  figure  shows  a  single  MAC  to  control  services  provided  from 
both  physical  layers.  This  structure  requires  a  Dual  Attachment  Station  (DAS)  with  a 
single  MAC.  The  high  throughput  achievement  is  essentially  based  on  the  use  of  the  dual 
trunk  ring;  therefore,  slave  stations  which  are  single  attached  to  concentrators  will  take 
advantage  of  the  improvement,  however  they  do  not  contribute  to  this  process.  The 
proposed  solution  for  the  problem  of  Single  Attached  Stations  (SAS)  with  the 
simultaneous  use  of  both  tings  in  this  protocol  is  to  provide  a  Dual  Attached 
Concentrator  (DAC)  with  an  enhanced  MAC  capability.  This  MAC  has  the  same 
structure  of  all  MACs  of  Dual  Attached  Stations  on  the  trunk  ring  with  an  additional 
capability  to  respond  for  each  of  its  slaves  as  if  each  slave  is  directly  attached  to  the  dual 
trunk  ring. 

The  single  MAC  organization  adds  a  degree  of  complexity;  however,  the 
benefits  overcome  this  cost.  Synchronization  of  both  rings  in  a  data  transfer  at  1(X) 
Megabits  per  second  is  a  challenging  problem  to  solve  in  an  FDDI  implementation  that 
uses  dual  MAC;  however,  with  a  single  MAC  controlling  both  ring  transmissions  this 
problem  seems  to  have  a  feasible  solution.  In  FDDI,  a  station  MAC  placed  in  one  ring 
is  not  allowed  to  communicate  with  a  MAC  placed  in  another  ring.  In  the  protocol 


46 


47 


devdoped  in  this  thesis,  the  solution  proposed  for  a  dual  ring  operation  is  a  Single-MAC- 
Dual-PHY  structure.  This  unique  structure  has  to  be  more  complex  than  the  current 
structures  q)ecified  by  FDDI.  Due  to  its  complexity,  this  Single-MAC-dual-PHY 
structure  can  be  a  subject  for  more  work  conducting  an  in  depth  analysis. 

One  advantage  of  a  single  MAC  to  control  the  operations  of  both  rings  is  the 
enhancemoit  of  end-end  connectivity  through  ring  configuration  changes.  In  [Ref.  16] 
Strohl  analyzes  two  troublesome  cases  for  a  dual  MAC  station  to  ensure  connectivity  if 
both  rings  are  used  for  data  transmission.  The  problem  deals  with  determination  of  the 
correct  MAC  to  maintain  communications  through  configuration  changes  (WRAP  to 
THRU  and  THRU  to  WRAP).  The  Two  cases  are: 

•  The  ring  is  in  a  WRAP  condition  and  two  stations  establish  a  connection.  Then, 
the  configuration  changes  to  THRU.  The  connected  MAC  can  no  longer 
communicate  since  they  are  on  diffmrat  rings.  The  problem  is  determination  of 
MAC  placements  of  a  dual  MAC  wrapped  station  when  the  configuration  changes 
to  THRU  in  order  to  choose  the  correct  MAC  to  maintain  communications. 

•  The  ting  is  in  a  THRU  condition  and  two  stations  establish  a  connection.  Then, 
one  of  these  stations  wrsqis  with  one  of  the  connected  MAC  off  of  the  wrapped 
ring.  This  disrupts  the  communication  path. 


With  a  Single-MAC-Dual-PHY  structure  these  problems  no  longer  exist  since 
if  a  configuration  change  occurs  on  the  network  this  MAC  continues  in  the  path  to  allow 
stations  connection.  Therefore,  this  MAC/PHY  structure  enhances  end-end  connectivity 
through  configuration  changes.  Connectivity  is  never  lost  with  a  single  MAC  controlling 
access  to  both  rings. 
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2.  Changes  in  the  Original  Protocol 

To  allow  concurrent  access  to  the  physical  medium  and  simultaneous  use  of 
both  rings  two  basic  changes  are  implemented  in  the  original  FDDI.  The  first  change  is 
die  establishment  of  dynamic  logical  partitions  on  both  rings.  As  a  result  of  these 
partitions,  a  change  in  the  method  of  striping  the  frames  from  the  rings  is  necessary. 
Three  logical  segments  divide  the  physical  medium  in  the  improved  protocol.  Figure  14 
illustrates  these  partitions.  Three  stations  on  the  ring  form  the  vertices  that  join  the  three 
segmrats.  One  station  is  the  token  holding  station  (THS),  which  captured  the  token. 
There  will  be  only  one  token  circulating  on  this  dual  ring  network.  The  tol^  holding 
station  establishes  the  ring  partitions  by  transmitting  frames  simultaneously  on  both  rings 
in  opposite  directions.  The  Destination  Addresses  (DA)  contained  in  each  of  the  two 
frames  establish  the  two  other  vertices  on  the  partitioned  rings.  The  segmmt  of  the  rings 
not  covered  by  transmissions  of  the  token  holding  station  can  be  used  by  a  second  station 
to  transmit  its  data  concurrently  on  the  ring.  Therefore,  two  stations  can  access  different 
parts  of  the  medium  at  the  same  time. 

Ckmcurrent  use  of  the  physical  medium  requires  changes  in  the  method  of 
frame  removal  from  the  ring  and  acknowledgments  of  frame  received.  In  FDDI,  all 
frames  make  a  complete  rotatimi  on  the  ring  and  are  thoi  removed  by  the  their 
originators.  The  advantage  of  this  procedure  is  simplicity.  The  disadvantage  is  the 
innefficient  use  of  resources;  even  after  being  copied  by  the  destination  address  station 
the  frame  is  rq)eated  from  node  to  node  all  the  way  to  the  originator.  On  the  average 
half  of  the  transmission  time  is  used  for  frame  repetition  from  node  to  node  after  the  DA 
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Figure  14:  The  three  physical  medium  logical  partitions 

node  has  copied  the  frame.  The  allocation  of  a  second  ring  which  remains  unused  during 
normal  operation  further  aggravates  this  sihiation  of  inefficirat  use  of  resources.  In  the 
improved  protocol,  with  the  exception  of  MAC  frames,  which  need  the  full  ring  to 
perform  the  Ring  Initialization,  Claim,  and  Beacon  processes,  other  fnunes  are  not 
repeated  on  the  ring  all  the  way  up  to  its  originator.  Instead,  these  frames  are  removed 
by  the  destination  address  stations.  This  procedure  allows  the  use  of  a  freed  s^ment  of 
the  ring  to  be  used  by  any  statitm  within  that  segment  concurrraitly  with  the  main  token 
holding  station.  The  acknowledgmoit  is  sent  by  the  destination  address  station  on  the 
q^site  ring  in  a  segment  that  is  not  bdng  used.  As  opposed  with  the  acknowledgment 
embedded  in  the  frame,  which  is  rq)eated  downstream  up  to  the  frame  originator,  the 
new  MAC  employs  a  short  fixed-length  PDU  that  goes  back  on  the  opposite  ring 
immediately  after  the  frame  is  copied.  This  PDU  carries  no  information  field  but  only 
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the  necessary  sequences  of  symbols  for  the  frame  originator  MAC  to  provide  status 
report  service  to  other  «itities. 

The  concurrent  access  to  the  physical  medium  is  controlled  and  synchronized 
to  avoid  collisions.  Stations  may  have  many  PDUs  queued  each  with  a  different 
destination  address.  Also,  frames  are  variable  in  length  (duration);  some  can  be  frames 
of  short  duration  otho’  can  be  in  the  order  of  a  maximum  length  allowed  in  the  protocol. 
Therefore,  a  mechanism  to  manage  the  use  of  space  and  time  is  needed.  The  solution 
adopted  by  this  protocol  is  to  provide  another  type  of  PDU  that  controls  the  access  of  the 
second  transmitting  station  while  the  first  station  is  accessing  the  ring  during  normal 
operation.  This  PDU  called  "subtoken"  is  controlled  by  the  main  token  holding  station. 
This  station  generates  subtoken  information  for  concurrent  transmission  on  the  unused 
segment  of  the  ting.  The  next  subsection  presents  the  subtoken  and  the  acknowledgment 
format. 

3.  Flrotocol  Data  Units  (H)U)  Formats 

In  addition  to  frame  and  token  formats  used  in  the  original  FDDI,  this 
protocol  adds  two  other  fixed-length  PDU  formats:  subtoten  and  acknowledgmoit.  The 
purpose  of  the  subtoken  is  to  grant  stations  the  right  to  transmit  on  the  unused  segment 
of  ring.  Therefore,  the  subtoken  contains  fields  establishing  physical  limits  for 
transmission  on  the  ring.  Its  format  also  includes  a  field  that  gives  the  maximum  duration 
allowed  for  one  or  more  frames  to  be  transmitted  concurrently  with  the  frame  of  the 
token  holding  station. 
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The  acknowledgmoit  is  a  short  fixed-length  PDU  that  returns  on  the  other 
ling  in  opposite  direction  from  the  data  frame.  The  acknowledgment  is  srat  after  the 
lecdver  on  the  ring  of  the  incoming  frame  cq>ies  this  frame  into  its  input  buffer. 


Figure  IS  depicts  the  subtokra  format.  The  starting  sequence  (PA  field  and 
SA  fidd)  is  the  same  as  in  frame  or  toten.  The  subsequent  fields  are  as  follows: 


•  Frame  Control  (FQ  -  ccmsists  of  dght  bits  (two  data  quartets)  specified  by  the 
following  bit  format:  CLFF  ZZZZ,  whme  for  the  subtokm  they  are  1111  (XXX). 

•  Start  Limit  (SL)  -  consists  of  four  or  12  data  quartet  symbols  to  indicate  the 
address  of  the  station  where  the  subtoken  starts  to  be  valid  for  use. 

•  Ending  Limit  (EL)  -  consists  of  four  or  12  data  quartet  symbols  to  indicate  the 
address  of  the  station  where  the  subtotoi  stops  to  be  valid  for  use. 

•  Frame  Class  (CLASS)  -  consists  of  two  data  quartet  symbols  to  specify  an  upper 
bound  for  the  length  of  the  frame  to  be  sent  by  the  station  that  is  holding  the 
subtoken 

•  Ending  Delimiter  (ED)  -  same  as  in  token;  consists  of  a  pair  of  symbols  (T)  to 
indicate  a  subtoken  ending.  This  field  is  necessary  to  provide  a  criteria  for 
acceptance  of  a  valid  subtokm.  The  ED  must  be  met  before  a  subtokm  is  accepted. 
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Beginning  with  the  Start  Limit  address,  the  subtoken  is  "captured"  or  passed 
(Ml  from  staticm  to  station  downstream  on  the  ring  until  it  reaches  the  Biding  limit  (EL) 
address.  If  the  Ending  limit  station  does  not  use  the  subtoken  then  this  station  strips  it 
from  the  ring. 

This  protocol  employs  the  CLASS  field  in  the  subtoken  to  provide 
information  for  ring  scheduling  on  the  partitioned  segment  of  the  ring.  Classes  represent 
time  duration  of  frames.  Figure  16  depicts  the  formation  of  classes.  As  the  figure 
illustrates,  classes  can  be  a  step-wise  or  sampled  discrete  function  of  frame  length. 


(a)  Step-wise  Sample-discrete 

das  cloB 


Figure  16:  Classes  as  a  Stq>-wise  or  Sampled-discrete  Function  of  Frame  Length 


53 


In  the  step-wise  representation  of  Figure  16,  10  classes  beginning  from  zero 
through  nine  are  nu^ped  to  intervals  of  jfirame  lengths  in  multiples  of  SOO  octets  from 
zero  through  the  maximum  frame  length  of  4500  octets.  The  third  Class  Cj  in  this 
example  corresponds  to  a  number  of  symbol  times  calculated  for  the  interval  (SOO,  1(XX)] 
of  octets.  If  a  step-wise  formation  of  classes  is  adopted  the  number  of  classes  could  be 
implementor  defined.  In  this  case,  the  granularity  of  classes  could  depend  upon  the  size 
of  files  used  in  the  application  for  the  FDDI  network.  In  the  sampled-discrete  case,  there 
are  virtually  as  many  classes  as  discrete  sizes  of  frames;  however,  for  short  frames  it  is 
reasonable  to  consider  a  mapping  to  a  zero  duration  class  because  these  frames  of  short 
duration  cannot  be  used  in  the  process  of  concurrent  access. 

Classes  are  measured  in  number  of  symbol  times  at  1(X)  Megabits  per  second. 
The  number  of  symbol  times  for  each  class  must  be  determined  for  the  network  to  ensure 
adequate  transmission  of  data  concurrently  on  the  ring. 

The  main  tokm  holding  station  establishes  the  class  of  the  subtoken  according 
to  the  length  of  the  two  frames  which  are  transmitted  simultaneously.  The  token  holding 
station  assigns  a  subtoken  Frame  Class  that  corresponds  to  an  interval  of  frame  Iragth 
calculated  by  that  MAC  station  based  on  the  both  frames  queued  for  transmission.  In  the 
noct  subsectirm,  algorithms  to  generate  classes  for  the  life  of  subtoken  are  discussed.  The 
station  that  uses  the  subtoken  can  only  transmit  a  frame  during  the  extent  of  that  received 
frame  Class. 
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Any  station  which  address  falls  within  the  subtoken  limits  may  gain  the  right 
to  transmit  by  capturing  the  subtoken.  However,  this  may  only  occur  under  the  following 
conditions: 

•  The  candidate  station  may  only  transmit  frames  addressed  to  stations  that  are 
physically  within  the  limits  established  by  the  subtoken  fields  SL  and  EL  of  that 
particular  subtoken. 

•  The  candidate  station  may  only  transmit  frames  that  have  Iragth  bounded  above  by 
the  class  of  frame  defined  by  be  subtoken  field  CLASS  of  that  particular  subtoken. 

These  conditions  avoid  collisions  and  allow  controlled  concurrent  use  of  the 
partitioned  rings. 

Figure  17  depicts  the  acknowledgment  format.  The  acknowledgment  follows 
the  same  format  pattern  of  a  frame  in  the  original  FDD!  protocol,  except  that  the  INFO 
and  FCS  fields  do  not  appear.  The  Destination  Address  (DA)  in  the  acknowledgment 
fomut  corresponds  to  the  address  of  the  received  frame  originator,  and  the  Source 
Address  (SA)  conesponds  to  the  station  that  is  forwarding  the  acknowledgment. 

The  Ending  Ddimiter  (ED)  and  Frame  Status  (FS)  fields  are  the  same  as  in 
the  frame;  however,  the  FS  field  in  the  fixed-loigth  acknowledgment  consists  of  exactly 
the  three  control  indicator  symbols  for  Error  Detected  (FS.E),  Address  Recognized 
(FS.A),  and  Frame  Copied  (FS.C).  There  is  no  trailing  terminate  ”T”  symbol  after  the 
FS  field  symbols  since  one  "T”  symbol  from  the  ED  field  plus  three  control  indicators 
of  FS  fidd  form  a  seqtmice  of  symbol  pain  required  by  MAC  FDDI  standard. 
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Figure  17:  Acknowledgment  Format 

A  different  procedure  adopted  on  the  process  of  acknowledgment  contributes 
to  still  more  improvemoit.  This  difference  is  in  the  way  the  acknowledgment  is  routed 
to  the  originator.  In  the  original  protocol,  the  receiving  station  matches  the  DA  field  to 
its  own  address,  copies  the  frame  and  sends  the  acknowledgment  inside  the  frame  on  the 
primary  ring.  In  the  improved  protocol,  after  the  receiving  station  scans  the  received 
Destination  Address  (DA,)  and  a  match  occurs  with  its  own  address,  it  strips  the  frame 
from  the  primary  ring  as  it  is  copied  to  the  local  entity.  After  the  frame  is  received  and 
copied  the  station  transmits  an  acknowledgmoit  back  to  the  originator  on  the  opposite 
ring.  This  procedure  avoids  unnecessary  frame  jnopagation  and  it  frees  a  segmrat  of  both 
rings  for  the  candidate  stations  to  use  the  subtoken  on  that  part  of  the  rings. 

B.  THE  TIMED^TOKEN  CONTROLLED  CONCURRENT  ACCESS 

The  format  of  the  additional  protocol  data  units  have  been  described.  Provided  that 
information,  this  section  presents  a  more  detailed  description  of  how  concurrent  access 
with  simultaneous  transmissicms  on  both  tings  can  be  achieved  in  this  protocol. 
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The  main  token  holding  station  is  re^nsible  for  providing  the  necessary 
informatiini  to  allow  other  station’s  MACs  to  work  cooperatively  on  the  dual  ring.  This 
is  accomplished  as  follows.  Assume  that  there  is  synchronous  traffic  queued  for 
transmission.  The  traffic  is  distributed  for  transmission  among  the  two  physical  medium 
using  a  balance  loading  algorithm  to  improve  efficiency.  There  are  two  queues  for  this 
service;  one  for  each  ring.  The  Service  Data  Units  (SDU)  are  placed  in  the  frames  and 
oiqueued  for  transmission.  The  process  begins  when  a  passing  token  is  captured  by  a 
station  as  in  the  original  FDDI  as  shown  in  Figure  18. 

Totwn  Holding  Station 


laate  with  nfatokcB 

sirmH 

■Si 

tokeo  caiMiiied 

auiUH 

ps 

. < 

■  -J 

mQiiii 

aobtoh 

■■I 

R  T 


Figure  18:  The  Tokm  Holding  Station  Simultaneous  Transmission  on  Both  Rings 

This  station  begins  transmission  of  the  two  head  queued  frames  simultaneously  on 
both  rings.  One  of  these  two  frames  will  carry  additional  information  to  allow  a  posterior 
formation  of  the  subtokoi  as  a  sqianUe  PDU.  This  frame  will  be  the  frame  mth 
subtoken.  The  other  frame  is  transmitted  simultaneously  on  the  opposite  direction  without 
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the  subtoken  information.  The  MAC  Transmitter  in  charge  of  creation  of  the  frame  with 
subtoken  ins^  the  Destination  Address  (DA)  from  the  frame  without  subtoken,  queued 
on  the  other  ring,  in  the  first  eight  or  12  symbols  of  the  frame  INFO  freld.  The  DA  will 
become  the  subtoken  Ending  Limit  (EL)  in  the  subtoken  PDU  format.  Furthermore,  the 
Transmitter  will  insert  immediately  after  these  symbols,  the  duration  measured  in  symbol 
times  at  100  Megabits  per  second  that  a  station  will  be  allowed  to  transmit  whm  using 
the  subtoken.  This  duration  corresponds  to  a  CLASS  value  in  the  subtoken  format. 
Figure  19  depicts  the  contents  of  the  frame  with  and  without  subtoken  information.  The 
figure  shows  the  formation  of  the  subtoken  contents.  The  two  types  of  frames  are 
summarized  as  follows: 

•  Frame  with  subtoken  -  issued  by  the  token  hdding  station  only.  It  carries  the 
subtoken  information  and  the  Service  Data  Unit.  When  the  protocol  is  in  the 
"WRAP”  mode  the  token  holding  station  does  not  issue  frames  with  subtoken. 

•  Frame  without  subtoken  -  issued  by  dther  the  tokra  holding  station  or  the  subtoken 
holding  station.  This  frame  is  the  same  as  the  employed  by  the  original  FDDI. 

Once  the  frame  with  subtoken  reaches  the  destination  address  (DA)  station  the 
subtoken  is  ready  to  be  used  by  any  station  within  the  ring  segmrat  limits  beginning  from 
this  DA  station  up  to  a  Ending  Limit  (EL)  station  established  by  this  field  in  the  subtok^i 
format.  Thmfore,  the  frrst  candidate  station  to  use  this  subtoken  is  the  frame  destination 
address  statitm  itself. 
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Figure  19:  Formation  of  Subtoken  Contents 


1.  Algorithms  to  Generate  Subtoken  Duration  (Class) 

Two  algorithms  to  goierate  the  duration  of  the  subtoken  are  presented.  The 
first  algorithm  is  simpler,  generates  less  number  of  subtokens;  consequently,  imposes  less 
overhead.  However,  if  head  queued  frames  on  each  ring  differ  substantially  in  length  one 
segment  of  the  ring  may  become  unusable  waiting  until  completion  of  other  ring  frame 
transmission.  The  subtoken  duration  in  this  algorithm  is  calculated  based  on  the  largest 
of  the  two  frames.  The  second  algorithm  has  one  step  more  than  the  first  one,  graerates 
more  subtokens  and  can  make  more  use  of  the  ring;  however,  adds  more  overhead.  The 
next  paragraphs  will  present  the  initial  assumptions  and  the  two  algorithms  with  practical 
illustrations  of  their  first  iterations. 
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Assume  that  Class  is  the  same  as  frame  length.  Also,  assume  that  a  station 
has  captured  a  token  and  is  ready  to  initiate  its  simultaneous  transmissions  on  both  rings 
with  the  load  balanced  on  both  queues.  The  first  algorithm  is  described  as  follows: 

•  Get  the  Class  from  the  head  of  the  queue  for  the  primary  ring  and  the  Class  from 
the  head  of  the  queue  for  the  secondary  ring. 

•  Compare  these  last  two  Classes.  If  they  are  equal  take  this  value;  otherwise,  choose 
the  largest  of  the  two  Classes.  The  value  chosen  becomes  this  subtoken  duration 
(Class). 

•  After  completion  of  frame  transmission  go  to  the  first  step.  Repeat  the  process  until 
either  the  station  completes  its  transmissions  or  the  synchronous  bandwidth 
allocation  for  this  station  transmissions  terminates  or  the  THT  expires. 

Figure  20  illustrates  the  first  two  iterations  of  the  algorithm.  The  figure 
shows  a  bar  chart  that  represents  frames  enqueued  for  transmissions  on  both  rings  and 
the  resultant  duration  of  the  subtoken.  In  addition,  the  figure  shows  a  dual  ring 
architecture  with  20  stations  and  the  simultaneous  transmission  carried  out  by  station 
number  one,  which  holds  the  token.  Numerical  examples  are  shown  to  enhance  the 
illustration. 

In  this  algorithm  the  subtoken  can  go  in  either  direction;  however,  it  is 
assumed  by  default  that  it  goes  in  the  same  direction  of  the  token.  In  this  example,  the 
first  subtoken  can  be  used  by  any  station  beginning  from  address  three  up  to  address  IS 
and  it  allows  transmissions  within  these  limits  that  take  a  maximum  of  1500  octets.  Note 
that  this  duration  corresponds  to  length  of  the  frame  queued  on  the  primary  ring. 
the  frames  have  unequal  length,  one  segment  will  complete  its  transmission  earlier  than 
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Figure  20:  Illustration  of  the  first  Algorithm 
the  other;  consequently,  this  segment  will  wait  for  the  completion  of  the  other  when  both 


reinitiate  a  new  simultaneous  frame  transmission.  The  figure  shows  the  four  timing  steps 
on  the  dual  ring  operation  during  the  allocated  bandwidth. 


The  second  algorithm  makes  full  time  use  of  both  segments.  It  is  described 


as  follows: 


•  Get  the  Class  from  the  head  of  the  queue  for  the  primary  ring  and  the  Class  from 
the  head  of  the  queue  for  the  secondary  ring. 

•  Compare  these  last  two  Classes.  If  they  are  equal  take  this  value;  otherwise,  choose 
the  shortest  of  the  two  Classes.  The  value  chosen  becomes  this  subtoken  duration 
(Class). 

•  Save  what’s  left  over  from  the  last  comparison  as  a  last  Class. 
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•  Get  the  next  Class  from  the  queue  for  the  ring  which  had  the  last  shortest  Class 
and  go  to  the  second  step.  Repeat  this  process  until  either  the  station  complete  its 
transmissions  or  the  synchronous  bandwidth  allocation  for  this  station  transmissions 
terminates  or  the  THT  expires. 


Figure  21  illustrates  the  application  of  this  algorithm  for  the  same  data 
presented  in  Figure  20.  In  this  algorithm,  the  subtoken  goes  on  the  ring  that  last 
terminate  a  frame  transmission.  An  exception  for  this  condition  is  the  first  simultaneous 
frame  transmission  or  when  there  is  a  match  such  that  both  rings  reinitiate  their  frames 
transmissions  at  the  same  time.  In  this  case,  the  subtoken  can  go  in  either  one  or  another 
ring. 
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Figure  21:  Illustration  of  the  Second  Algorithm 


Figure  21  shows  that  the  second  algorithm  increases  utilization  of  both  rings 
since  one  ring  does  not  wait  the  opposite  ring  to  complete  the  transmission  of  its  current 
frame.  As  the  illustration  shows,  there  is  a  saving  in  the  bandwidth  for  simultaneous 
transnussion  if  compared  with  the  previous  example.  Also,  the  illustration  shows  that  this 
algorithm  increased  the  number  of  subtokens  generated  by  the  token  holding  station. 
However,  this  algorithm  leads  to  less  use  of  the  subtoken  ring  segment.  When  the 
calculated  duration  of  the  subtoken  becomes  too  short  the  token  holding  station  might  not 
issue  this  subtoken;  consequently,  some  available  time  on  this  third  segmrat  of  the  rings 
is  not  used.  In  addition,  this  algorithm  imposes  more  overtiead  as  a  result  of  these 
decisions  and  the  increased  number  of  subtotens  with  short  durations. 
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This  thesis  uses  the  first  algorithm  in  the  formal  specification  of  the  improved 
protocol.  This  decision  was  primarily  based  on  the  simplicity  of  the  first  method.  Both 
algorithms  increase  throughput  and  a  more  complete  analysis  such  as  the  use  of  a 
simulation  model  would  enhance  the  list  of  pros  and  cons  for  each  method. 

2.  Destination  Address  Station  Actions 

The  MAC  station  corresponding  to  the  frame  destination  address  (DA)  is 
responsible  to  take  several  actions  in  this  process  of  concurrent  ring  access.  First,  it 
scans  the  field  contents  of  the  incoming  frame  and  checks  the  Frame  Control  (FC)  to 
verify  the  type  of  PDU;  note  that  in  this  protocol  the  FC  field  is  also  used  to  differentiate 
frames  that  carry  subtoken  information  from  frames  that  do  not  include  it.  Second,  the 
station  matches  the  frame  DA  with  its  own  address  and  begins  to  copy  the  frame  into  its 
receive  buffer  while  taking  actions  to  remove  this  frame  from  the  ring.  If  the  frame 
contains  the  subtoken  contents  then  the  station  may  use  the  subtoken  or  not.  In  the  case 
of  subtoken  use,  the  station  immediately  begins  transmission  of  its  PDU  downstream  on 
the  ring  while  receiving  the  data  upstream  from  the  token  holding  station.  The  timing 
mechanism  of  concurrent  access  shall  work  such  that  it  is  expected  that  the  traffic 
downstream  terminates  before  the  traffic  upstream  and  both  stations  had  received  an 
acknowledgment  back  on  the  opposite  ring.  Finally,  in  the  case  of  unusable  subtoken  the 
station  immediately  extracts  the  subtoken  contents  from  the  frame  and  issues  the  subtoken 
as  a  separate  PDU  downstream  on  the  ring  to  be  used  by  another  station  on  the  freed  ring 
segment. 
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Stations  pass  the  subtoken  if  they  can  not  use  it.  The  subtoken  passing  process 
continues  until  it  reaches  the  last  station  on  the  unused  segment  when  this  station  finally 
removes  the  subtoken  hrom  the  ring.  If  the  subtoken  is  used  before  it  reaches  the  ending 
limit  the  station  that  uses  the  subtoken  is  responsible  for  its  removal  from  the  ring  (i.e., 
the  subtokrai  is  not  reissued).  The  subtoken  can  be  used  only  once. 

3.  Reconfiguration 

An  important  issue  to  discuss  is  the  reliability  provided  if  the  changes  are 
implemented  in  the  FDDI  protocol.  Basically,  FDDI  provides  fault  tolerance  with  a  dual 
counto'-rotating  ring  because  of  its  "WRAP  mode,"  in  which  stations  reconfigure  to 
isolate  a  serious  ring  or  node  failure.  In  this  case,  the  dual  logical  ring  becomes  a  single 
path  allowing  communication  to  continue. 

The  improved  protocol  also  provides  this  feature  but  with  the  loss  of 
enhanced  ring  utilization.  "WRAP"  is  a  property  of  a  station  in  the  original  FDDI; 
however,  an  overall  network-controlling  function  can  monitor  the  network  to  detect 
station’s  wrap.  The  stations  on  dther  side  which  reconfigured  to  isolate  the  failure  notify 
SMT  and  a  global  variable  Wrap  is  set  to  true.  The  stations  recognize  that  only  one 
logical  ring  is  active  and  the  stripping  of  frames  revert  to  the  original  FDDI  with  the 
acknowledgmoit  srat  inside  the  frame. 
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IV.  FORMAL  SPECIFICATION 

This  chs^ter  presents  the  formal  sp^ificadon  for  the  Media  Access  Control  (MAC) 
protocol  developed  in  this  thesis  using  Systems  of  Communicating  Machines. 

A.  BENEFITS  OF  A  FORMAL  SPECOTCATION 

One  of  the  nudn  purposes  of  a  formal  specification  is  to  provide  enhancements  in 
its  interpretation.  One  of  the  problems  pointed  out  in  the  interoperability  issue  is  that  the 
interpretation  of  the  standard  itself  is  ambiguous  [Ref.  14].  Among  other  problems,  the 
following  example  was  given: 

It  appears  to  be  possible  to  take  in  the  symbol  sequence  I  J  I,  which  is  an  error 
condition,  and  still  conform  to  the  FDDI  standard.  This  causes  oscillations  of  the 
ring. 

A  formal  model  such  as  the  one  used  in  this  thesis  helps  to  identify  and  isolate 
problems  of  this  nature.  To  illustrate  this  specific  case,  the  model  specifies  a  MAC 
receiver  checking  for  a  strip  on  the  incoming  symbol  sequence  which  forms  the  SD  field 
of  the  PDU.  Since  there  is  an  "I"  symbol  after  the  symbol  it  means  that  a  transition 
Strip  on  SD  holds  true  on  the  Receiver,  (see  MAC  Receiver  state  diagram  and  transition 
table).  The  MAC  Receive  sends  a  signal  "Idle"  to  the  Transmitter  and  raters  the 
AWAIT  SD  state.  The  receipt  of  "Idle"  »gnal  from  the  Receiver  enables  a  transition  7k 
IdU  Symbols  ra  the  Transmitter  side  which  raters  the  IDLE  state.  Symbols  are  checked 
one  by  one  leaving  no  ambiguities. 


The  model  Systems  of  Communicating  Machines  can  also  be  applied  to  the 
specification  of  the  protocol  physical  layer  and  in  this  case  the  sequence  of  operations 
would  consider  the  code  bit  level.  This  provides  a  better  document  interpretation  and 
contributes  to  interoperability  in  multivendor  computing  environments. 

The  FDDI  Media  Access  Control  standard  presents  subclauses  containing  the  MAC 
structure  functional  specification.  The  MAC  structure  defines  two  asynchronous  processes 
that  work  as  co-operating  state  machines,  called  the  MAC  Receiver  and  the  MAC 
transmitter.  The  standard  presents  the  overall  processes  operation  in  the  form  of  state 
diagrams  and  attached  notes.  These  diagrams  show  the  transitions  that  take  place  between 
the  states.  In  addition  to  state  diagrams  the  standard  uses  prose  in  the  specifications, 
although  it  states  that  the  state  diagrams  shall  take  precedence  in  the  event  of  any 
discrepancy.  The  standard  provides  all  the  specifications  but  lacks  the  use  of  a  formally 
defined  model  in  its  protocol  specifications. 

The  MAC  specification  used  in  this  thesis  has  some  similarities  and  differences 
from  the  MAC  specification  used  in  the  FDDI  MAC  standard.  They  are  similar  in  that 
both  use  processes  of  co-operating  machines  represented  in  state  diagrams.  They  use  the 
similar  terminology  as  defined  in  the  previous  subclauses  of  the  MAC  and  other  FDDI 
standards.  They  differ  in  that  the  specifiaition  presented  in  this  thesis  uses  a  formal 
model.  The  model  is  used  to  specify  the  entire  protocol;  however,  it  also  sq>plies  to 
hierarchies  of  small  indqpendent  modules  such  that  it  captures  the  aspects  of  the  protocol 
behavior  and  structure  relevant  to  the  development  team.  Furthermore,  the  application 
of  the  formal  model  forces  a  much  more  detailed  consideration  of  the  protocol  which 


67 


makes  the  functional  specification  more  precise.  This  technique  provides  a  refinement  of 
the  MAC  protocol  specification. 

The  formal  specification  of  the  Media  Access  Control  protocol  contributes  to 
enhance  the  standard  functional  specification  in  several  ways: 


•  Provides  precise  control  over  each  protocol  module  or  state  behavior. 

•  Improves  understanding  of  the  protocol  functionality.  Modules  are  understandable 
in  isolation.  For  a  complex  protocol  such  as  FDDI,  this  is  a  desirable  property. 

•  Reduces  documented  protocol  ambiguities.  The  decomposition  into  small 
independent  modules  provides  a  clear  relation  between  each  module  and  the 
protocol  fimctional  specification. 

•  Confines  changes  in  design  decision  to  a  single  module.  If  the  protocol  needs 
changes  then  this  will  not  depend  on  the  entire  specification. 

•  Provides  means  to  conduct  a  protocol  analysis  for  its  correctness.  Proofs  for 
protocol  correctness  can  be  established. 

•  Easier  to  test  the  protocol.  Decomposidon  and  modular  specification  simplify 
testing  of  each  protocol  module. 


The  decomposition  of  bigger  states  into  a  hierarchy  of  smaller  states  obtaining  a 
lurecise  control  of  the  a  state  behavior  simplifies  the  description,  protocol  verification  and 
implementation.  The  cmitrol  over  each  state  is  a  good  feature  for  identification  of 
nudfiinctions  within  each  state.  This  allows  develq)ment  of  protocol  test  procedures, 
verificaticm  and  error  diecldng.  The  understanding  of  protocol  functionality  is  improved, 
since  at  any  given  moment  a  transition  from  one  state  to  another  can  be  checked  by 
following  the  preceding  history  of  operations  in  the  himrchy  of  states  and  the  transition 
table  logical  sequences. 
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The  formal  definition  of  each  logical  operation  in  sq)arate  states  avoids  documented 
protocol  ambiguities  and  improves  interpretation  for  implementation  purposes.  The 
functional  specification  for  MAC  frames  in  the  Receiver  are  treated  differently  from  the 
specification  of  LLC  frames  because  some  2u:tions  will  not  be  the  same  for  both  types  of 
frames.  These  are  treated  in  different  protocol  modules.  Even  states  that  perform  similar 
functions  receive  individual  treatment  within  each  branch  of  the  transition  state  diagram. 

One  relevant  question  is  how  deep  the  decomposition  into  smaller  states  will  be? 
Does  the  number  of  states  and  transitions  increases  to  a  point  such  that  it  becomes 
unworkably  large?  The  decomposition  of  states  will  go  up  to  the  level  where  no 
ambiguity  is  left.  All  the  internal  events  described  in  the  standard  documentation  which 
cause  an  action  are  considered.  A  modular  decomposition  allows  an  easier 
implementation  of  large  systems. 

Since  the  specification  goes  to  a  deep  level  of  details  in  terms  of  transitions  and 
states,  it  is  impractical  to  explain  all  these  details  in  one  chj^ter.  The  reader  is 
encouraged  to  study  the  MAC  FDDI  standard  specification.  The  changes  implemented 
in  FDDI  to  achieve  the  improvement  will  alter  some  modules  of  the  original  FDDI; 
however,  the  overall  functions  are  the  same. 

B.  MODELING  THE  IMPROVED  PROTOCOL 

1.  Ntrtational  Conventions 

The  following  notation  is  used  in  the  transition  tables: 

•  V  :  logical  or 
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•  A  :  logical  and 

•  “•  :  logical  not 

•  9  :  such  that 

•  E  :  member  (element) 

•  A«-B  :  places  the  current  value  of  B  into  A 

In  the  state  diagrams,  states  are  represented  by  bubbles  and  transitions  by 
arrows.  A  state  is  numbered  by  a  letter-number  and  is  named  with  capital  letters  which 
dppcar  inside  the  bubble.  The  letter-number  is  organized  within  each  module  of  the 
diagram  such  that  the  letter  corresponds  to  the  first  letter  of  the  module  name  and  the 
number  correspmds  to  the  number  of  states  within  the  module.  A  transition  is  named 
with  lower  case  letters  (except  for  the  first  letter  or  acronyms  used  to  form  the  name)  and 
appears  in  the  right  side  of  the  arrow  between  two  states. 

2.  The  Communicating  Machines 

Figure  22  dqncts  the  communicating  machines.  There  are  four  machines  that 
woiic  cooperatively  on  both  rings.  At  die  node  i  the  machines  Tjl  and  Rjl  are 
respectively  the  Transmitter  and  Receiver  on  ring  1  while  Tj2  and  Rj2  stand  for 
Transmitter  and  Receiver  on  Ring  2.  Machines  in  one  ring  are  symmetric  with  machines 
of  same  name  the  other  ring.  This  allows  for  the  MAC  to  choose  dther  one  or  the 
other  ring  to  circulate  the  main  token.  Also,  this  propmty  allows  the  rqiresentation  of 
states  for  only  (me  Recdver  and  only  (me  Transmitter. 


Figure  22;  The  Four  Communicating  Machines  of  a  Network  Node 


Receivers  and  transmitters  behave  differently  in  the  communication  process. 
While  a  Receiver  communicates  simultaneously  with  both  Transmitters  a  Transmitter  can 
only  communicate  with  a  Receiver  on  the  same  ring.  A  simultaneous  communication  of 
a  Receiver  with  both  transmitters  means  that  actions  taken  by  a  Receiver  are  visible  to 
both  transmitters.  However,  the  Media  Access  Control  establishes  the  control  of  the 
action  based  on  the  nature  of  this  action  and  its  originator. 


3.  Modeling  The  Interface  Operations 

There  are  four  operations  on  the  FDDI  network  specified  by  this  formal 
model.  These  are  receive,  receive-copy,  rq)eat,  and  transmit  symbols. 

Figure  23  illustrates  the  logical  operations  carried  out  in  a  single-MAC-dual- 
PHY  interface.  For  each  ring  there  is  one  input  variable  of  type  buffer  denoted  as 
PH_Indication(symbol)  and  one  ou^ut  variable  of  type  buffer  denoted  as 
PH_Request(symbol).  These  are  shared  variables  through  which  the  machines 
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communicate.  Each  name  is  an  analogy  to  the  service  primitive  provided  at  the  interface 
MAC/PHY.  Symbol  is  a  pointer  associated  with  these  buffers.  The  pointer  locates  a 
symbol  on  the  array  of  symbols  and  is  sequentially  incremented  at  each  new  symbol 
arrival  on  the  receiver  side  or  new  departure  on  the  transmitter  side.  In  this  model,  a 
variable  of  type  buffer  is  specified  by: 

type  biffer.  anay[l..MFL+l]  of  symbol; 
where  MFL  is  the  maximum  frame  length. 

Each  transmitter  maintains  other  variables  of  type  buffer  dedicated  for 
transmission  of  its  PDU  queued.  The  synchronous  service  is  provided  with  the  S- 
buf(symbol)  and  the  asynchronous  with  the  A-buf(symbol).  Each  receiver  uses  the  R- 
buf(symbol)  to  copy  the  PDU  that  matches  with  the  station’s  address. 

In  the  receive  symbols  operation,  bits  from  the  ring  enter  the  interface 
through  the  line  receiver  into  the  PH_Indication(symbol)  buffer  in  a  serial  fashion.  These 
bits  form  the  symbols  that  are  read  in  the  interface  PHY/MAC.  The  symbol  pointer  is 
incremented  to  the  next  symbol  and  a  symbol  counter  is  maintained.  For  the  receive 
symbols  of  a  frame  the  operation  is  rq)resented  as  follows: 

•  PH_Indication(symbol)  =  {  PA,[Ii..I«J,  SDJJ,K],  FC,[n,n],  DAJ4n  V  12n], 
SA,[4n  V  12nI,INFOJn,..n«J,FCS,(8n],EDjr],FS.E,[S/R],FS.AJS/R],FS.CJS/R] 
); 

•  symbol  symbol  +  1; 

•  symbol_ct  symbol_ct  +  1; 


In  the  receive-copy  symbols,  in  addition  to  the  previous  operation  bits  are 
copied  by  the  Receiver  into  its  receive  buffer.  This  operation  is  represented  as  follows: 

•  PH_Indication(symbol)  =  {  SD,[J,K],  FC,[n,n],  DA,[4n  V  12n], 

SA,[4n  V  12n],  INFO,[n,..n^,  FCS,[8n],  ED,IT].  FS.E,[S/R],  FS.A,[S/R],  FS.C,[S/R] 

}; 

•  Rcv-buf(symbol)  *-  PH_Indication(symbol); 

•  symbol  *-  symbol  +  1; 

•  symbol_ct  symbol_ct  +  1; 
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In  the  repeca  symbols  operation,  after  a  delay  these  bits  are  retransmitted  by 
the  Transmitter  over  the  ring  from  the  interface  MAC/PHY  either  unchanged  or  after 
some  modification.  The  representation  for  repeat  token  symbols  is  as  follows: 

•  PH_Indication(symbol)  =  {  PA[I,..IJ,  SD[J,K],  FC[CLFF,ZZZZ],  EDrr,T)  }; 

•  PH_Request[symbol]  ♦-  PH_Indication(symbol); 

•  symbol symbol  +  1; 

•  symbol_ct  *-  symboI_ct  +  1; 


In  the  transmit  symbols  operation,  bits  are  transmitted  serially  from  the 
interface  over  the  ring.  These  bits  come  from  the  appropriate  buffers  (synchronous  or 
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asynchronous)  and  sent  to  the  line  driver  for  transmission  out  of  the  PH_Request  buffer. 
The  representation  for  a  transmission  of  synchronous  frame  symbols  is  as  follows: 

•  S-buftsymbol]  =  {  PA,[I,..1J,  SD,[J,K],  FCJCLFF,ZZZZ],  DA,[4n  or  12n], 
SA,[4n  or  12n],  INFO,[n,..n^,  FCSJ8n],  EDJT],  FS.E,[R/S],  FS.A,[S/R],  FS.CJS/R] 
} 

•  PH_Request[symbol]  S-bufIsymbol]; 

•  symbol  symbol  +  1; 

•  symbol_ct  *-  symbol_ct  +1; 

4.  The  MAC  Receiver  Operation  and  Specification 

The  MAC  Receiver  machine  performs  several  operations  upon  receipt  of 
symbols  of  an  incoming  PDU.  It  receives  the  information  from  the  ring,  detects  format 
errors  on  the  field  sequences  which  form  each  type  of  PDU,  checks  frame  validity 
criteria  and  sends  appropriate  signals  to  the  Transmitter. 

As  the  symbols  of  the  incoming  PDU  arrive  in  a  serial  transfer  from  the 
Physical  Layer  (PHY)  to  the  Media  Access  Control  Layer  (MAC)  the  MAC  receiver 
machine  scans  the  input,  in  order  to  take  the  appropriate  action  as  required.  Figure  24 
illustrates  how  the  MAC  receiver  performs  these  operations. 

The  PH_Indication(symbol)  appears  on  the  left-hand  side  of  the  figure.  The 
right-hand  side  shows  the  format  of  the  incoming  PDU  and  the  sequence  of  transitions 
that  occur  whenever  the  corresponding  enabling  predicate  associated  with  each  transition 
holds  true.  For  example,  when  the  first  Idle  symbol  of  the  incoming  PDU  arrives  at  the 
PH_Indication(symbol)  buffer  a  Signal  Stan  transition  occurs  and  the  Receiver  takes  the 
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appropriate  actions.  In  general,  an  action  can  be  described  as  a  signal  sent  to  the 
Transmitter;  a  flag  setting;  a  variable  status  change;  or  an  integer  type  variable  increment 
such  as  counter,  timer,  or  pointer  increment.  In  this  example,  one  of  the  actions 
corresponding  to  the  Signal  Start  transition  is  the  increment  of  the  symbol  pointer  to  the 
next  symbol  of  the  sequence.  In  this  sense,  the  Receiver  continuously  scans  the  incoming 
stream  of  symbols  up  to  the  last  symbol  that  forms  the  complete  PDU. 


Figure  24:  The  Four  Types  of  PDU 


This  specification  is  more  det^ed  than  the  standard  because  in  this  model 
every  PH_Indication  is  considered.  This  corresponds  to  a  decoding  of  every  symbol  from 
the  physical  layer.  For  example,  when  the  Receiver  dq)arts  from  the  LISTEN  (RO)  state 
to  the  AWAIT  SD  (Rl)  state  due  to  the  arrival  of  the  first  idle  symbol,  this  model  will 
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also  consider  subsequent  idle  symbols  expressed  by  a  transition  called  Receive  Next  Idle 
Symbols.  This  transition  will  continue  to  occur  for  every  other  incoming  idle  until  the 
first  symbol  "J"  of  the  starting  delimiter  arrives.  Therefore,  the  model  allows  a  complete 
and  continued  checking  of  symbol  sequences,  which  is  exactly  what  the  MAC  protocol 
requires  for  its  correct  functionality.  This  strict  control  over  symbol  sequences  leaves  no 
ambiguities  regarding  the  protocol  acceptance  of  symbols.  The  same  reasoning  is 
followed  for  other  sequences  of  symbols  until  a  complete  PDU  has  been  received. 

As  Figure  24  illustrates,  the  PDU  for  the  improved  protocol  has  four  types 
of  formats.  Each  format  adopts  the  same  Starting  Frame  Sequence  (SFS)  as  FDDI. 
Immediately  after  the  SFS  there  is  the  Frame  Control  (FC).  By  scanning  the  FC  field  the 
Receiver  takes  one  out  of  four  types  of  PDU  to  follow  through  on  its  searching. 
Similarly,  the  Receiver  state  diagram  shows  four  main  branches,  namely;  Frame,  Ack, 
Subtoken,  and  Token  (as  in  Figure  24). 

a.  The  MAC  Receiver  State  IXagram  and  Transition  Table 

The  MAC  Receiver  State  Diagram  forms  a  closed  cycle.  A  hierarchical 
decomposition  and  a  history  on  the  sequence  of  operations  is  observed  in  each  part  as  the 
receiver  performs  the  checking  on  the  incoming  PDU.  These  operations  cover  all 
conditions  that  must  be  met  in  the  receiving  process  of  the  protocol. 

Figure  25  depicts  the  complete  MAC  Receiver  State  Diagram.  The 
purpose  of  this  figure  is  to  provide  a  picture  of  the  MAC  receiver  diagram.  This 
complete  diagram  is  formed  by  a  set  of  smaller  diagrams  contained  inside  the  rectangles 
which  are  presented  in  separate  figures.  There  are  10  smaller  diagrams  in  the  Receiver 
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MAC  RECEIVER  STATE  DIAGRAM 


Figure  25:  MAC  Receiver  State  Diagram 
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state  machine. 


The  MAC  Receiver  state  diagram  presents  the  receiving  process  in  five 
main  modules.  The  first  module  is  represented  by  Diagram  1  (Figure  26)  which 
corresponds  to  the  Receiver  scanning  Starting  Frame  Sequence  (SFS)  and  the  FC  field 
of  a  PDU.  After  the  completion  of  the  FC  scanning  the  Receiver  can  take  four  possible 
transitions  in  which  it  looks  for  frame,  ack,  subtoken,  and  token.  These  are  the  other 
four  modules  of  the  MAC  Receiver  State  Diagram.  The  Ack  module  has  two  diagrams 
and  the  Subtoken  and  the  Token  have  1  diagram  each. 

The  Frame  module  includes  Diagrams  2,  2a,  3,  4,  and  S.  Note  that 
unlike  the  specification  in  the  original  FDDI  standard,  which  does  not  cover  this  level 
of  diagram  specification,  in  this  decomposition  into  smaller  states  the  Receiver  checks 
for  arrival  of  different  entity  frames.  A  frame  which  arrives  at  a  station  with  the 
Destination  Address  (DA)  equals  to  its  own  Source  Address  (SA)  is  a  MAC  Claim 
Frame.  In  this  case,  the  station  has  recdved  its  own  Claim  Frame.  The  path  of 
transitions  goes  from  Diagram  2  to  Diagram  3.  The  station  will  copy  its  own  frame  into 
its  receive  buffer  and  sends  a  signal  My_Claim  to  the  transmitter  which  strips  the  frame 
and  begins  the  process  of  issuing  a  token.  Oi  the  other  hand,  if  a  fiame  arrives  with  DA 
not  equal  to  this  station  address  or  DA  null  then  the  transition  path  goes  from  Diagram 
2  to  Diagram  4  (D/i  ^  0  or  No  DA  Match).  In  this  case,  a  further  check  is  done  in  the 
SA  field  of  the  frame  to  verify  if  this  frame  is  the  station’s  own  Beacon  Frame;  if  it  is 
thoi  the  transition  goes  to  Diagram  S,  the  transmitter  will  be  signalled  with  My  Beacon 
and  that  MAC  will  attempts  to  recover  the  ring.  Otherwise,  the  path  goes  straight 
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through  Diagram  4  and  the  frame  can  be  either  an  upstream  Source  Address  Beacon  or 
a  downstream  Destination  Address  IXC,  SMT,  or  MAC  frame.  This  frame  will  be 
repeated  downstream  on  the  ring  by  the  transmitter. 

Furthermore,  if  a  frame  is  a  LCC  or  SMT  frame  which  was  sent  by 
another  station  to  this  station  then  the  transition  path  goes  from  Diagram  2  to  Diagram 
2a.  This  frame  will  be  copied  and  for  this  protocol  the  Receiver  will  send  an  Ack_Frame 
signal  to  the  Transmitter  on  the  opposite  ring,  which  in  turn  will  acknowledge  the  frame. 
In  this  case,  the  Receiver  sets  the  s^ropriate  flag  to  indicate  successful  copy  of  the 
frame  received.  The  purpose  of  this  brief  description  of  the  frame  module  is  to  show 
how  this  specification  avoids  ambiguities  and  provides  a  precise  control  over  the 
receiving  process  of  a  PDU.  Different  types  of  frames  during  different  phases  of  the 
receiving  process  imply  difierent  actions  which  are  considered  in  separate  modules.  An 
example  of  a  complete  path  of  transitions  in  a  frame  receiving  process  is  given  below. 

(1)  The  Destination  Address  Station  Receives  a  LLC  Frame  with 

Subtaken 


A  complete  cycle  path  of  transitions  for  receiving  one  LLC  firame 
with  subtoken  information  will  be  given.  Hie  path  begins  in  Diagram  1  goes  through 
Diagram  2  and  2a,  and  finally  reaches  Diagram  1  for  another  frame.  The  frame  is 
assumed  to  arrive  without  any  format  error;  is  a  complete  frame  (i.e.,  not  a  remnant), 
and  no  MAC  Reset  transition  or  PH_invalid  are  expected.  The  Receiver  copies  the  frame, 
checks  the  validity,  and  sends  the  a^ropriate  signal  to  the  Transmitter  on  tfie  opposite 
ring  to  carry  out  the  acknowledgment  process. 


80 


•  RO  Signal  Start  R1  Receive  Next  Idle  Symbols  R1  Start  R2  Receive  Next  SD  Symbol 
R2  SFS  Received  R3  Receive  FC  Symbols  R3  Frame  FO  Receive  DA  Symbols  FO 
DA  Match  FI  Copy  Frame  to  Local  Entity  (LLC)  F2  Receive jCp  SA  Symbols  F2 
Lower  SA  F3  ReceivejCp  INFO  Symbols  F3  DA=MA  LLC  With  Sbtk  F4 
ReceiveJCp  FCS,  ED  Symbols  F4  ED  ReceivedjCp  F5  Receive  Determine  FS 
Symbols  F5  Valid  Frame  F7  Frame  Copied  F8  Ack  Frame  F9  LLC  Frame  with 
DA-MA  Received  FIO  No  Error  Counted  R1 


A  finite  number  of  transition  paths  can  be  established  and  used  in 
the  chain-reaction  arguments  process  to  prove  the  protocol  correctness.  In  Chapter  V  a 
proof  for  the  previous  example  is  provided. 

The  other  modules,  hrom  Diagram  6  to  Diagram  9,  follow  the  same 
reasoning  in  the  process  of  receiving  a  PDU.  The  acknowledgment,  subtoken,  and  token 
modules  are  simpler  than  the  frame  module  since  these  PDUs  are  of  short-fixed  length 
and  carry  a  unique  type  of  information.  Similar  paths  of  transitions  to  receive  these 


PDUs  can  be  established. 


MAC  RECEIVER  STATE  DIAGRAM 


figure  26:  Receivo’  Diagnun  1 
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MAC  RECEIVER  STATE  DIAGRAM 

D  I  ag  .  2 

I  CSEE  DIAG. 


Rece i ve  DA 
Symbo I s 


1  \  aecoveI 

Reset 

t  ' 

\^[1A  ^ - 

1 nva  1  1  d 

Str  ip 
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SMT 

Next  Station 
Address i ng  FI  ag 

|Recelve_Cp  SA  Synbols 


- -I  »cv  CP  I  ' .  — 

Reset 

1  ova  1  1 

Strip 
on  SA 

My  SA 
- ► 

CSEE  DIAG.  33 


Higher 

SA 
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Reset 
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O  C/l 

o 

i - 

DA  >  MA 
LLC  or  SMT 
with  SbTk 


Recelved_CP  INFO  Syirbols 
Strip  Format 


AwiT  so 
OA  =  MA 
LCC  or  SMT 
Jwithout  SbTk 

I  R«ceiv«_Cp  FCS.,  ED  Symbols 


V  PCS.  J - 
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Str ip  on 

Reset 

1  ova  lid  T 
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ED 
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CSEE  DIAG.  2a3 


Figure  27:  Recdvo-  Diagram  2 


figure  29:  Recdvo*  Diagram  3 
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MAC  RECEIVER  STATE  DIAGRAM 
D i ag  .  4 


CSEE  DIAG.  2D 


OA  =  0  or 
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Race i ve  SA 
]  Synt>o  I  s 
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OCOC  Fcsr 
vifFtioiTir' 


Raceive  FS 


Format 

I  Error  on  FS 


1 
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Figure  30:  Receiver  Diagram  4 
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MAC  RECEIVER  STATE  DIAGRAM 
D  i  ag  .  B 


Amn  w 


Figure  32:  Receiver  Diagram  6 


7D 
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MAC  RECEIVER  STATE  DIAGRAM 
D  i  ag  .  7 


Figure  33:  Receiver  Diagram  7 
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C  RECEIVER  STATE  DIAGRAM 


Figure  34:  Receiver  Diagram  8 
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C  RECEIVER  STATE  DIAGRAM 


D  i  ag  .  9 


Figure  35:  Receiver  Diagram  9 
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Table  3  is  the  MAC  Receiver  Transition  Table.  The  table  contains  all  the 
transitions  showed  in  the  diagram.  Transitions  are  represented  by  short  words.  Same 
transitions  that  occur  in  different  protocol  modules  are  expressed  by  the  combination  of 
the  letter-number  of  the  outgoing  state  and  the  letter-number  of  the  entering  state. 
Transitions  in  which  symbols  are  being  received  show  the  enabling  predicate  with  the 
current  contents  of  the  PH_indication  buffer  and  the  current  position  of  the  "symbol" 
pointer  on  the  array  of  symbols  of  that  buffer.  All  boolean  variables  when  stated  solely 
by  their  names  on  the  enabling  predicate  are  assumed  to  be  true  unless  otherwise 
specified. 


TABLE  3:  MAC  RECEIVER  TRANSITION  TABLE 


j  Transitioo 

Enabling  Predicate 

Action  1 

Reset 

R(f,0);  F(f.O); 
A(s,0); 

S(0.0);  T(0,0); 
r-0, 1,2.3; 
f-0,2.3,4.5. 
11.12,13, 
17,18,19,20, 
24,25,26; 
s-0,1,2,3,4,5 
,6; 

MAC.Reset 

T_Neg  ^  T_Max; 

Signal  Start 
R(0.1); 

ra  hidication(8ymbol)  «  {  PAJIJ  }  A  (symbol 
-  PAJI,]) 

TVX*- reset; 

TVX  •-  enabled; 
symbol  •-  0; 
symbol  •-  s3anbol  +  1; 
SIGNAL  Idle; 

Invalid 

R(l.O); 

PH_InvaUd 

- 

Receive  Next 
Idle  Symbol 

PH_Indication(s3mdiol)  *  {  PA,II,],  } 

A  (symbol  PAAl  ^  l<i^max) 

symbol  *-  symbol  +  1; 
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Trinsitioa 


Enabling  Predicate 


Actitm 


Format  Error  I  PH_Indicati<m(symbol)  =  {  PA,[I,..Ik]  A 


on  SD 


Start 

R(l-2); 


Receive  Next 
SD  Syndml 
R(2-2); 


Strip  on  SD 
R(2*l); 


SFS  Received 
R(2-3); 


Receive  FC 

Symbols 

R(3-3); 


Frame 

R3-F0; 


Ack 

R3-A0; 


Strip  on  FC 
R(3-l); 


^SDJJJ) 


SIGNAL  FO_Error; 
Lo8t_Ct*-  L^_Ct  +  1; 
symbol  0; 


Invalid 

R(r,0);  F(f.O); 
A(a,0); 

S(0,0);  T(0.0); 
r=0,l,2,3; 


PH  Indication(symbol)  =  {  PAJI,..I_1,  SDJJJ  }  Idle  *-  off; 

SIGNAL  Rc_Start; 

A_.  C_,  E_,  N_,  H_,  L_, 
M_Flag  •-  clear, 
symbol  *-  symbol  +  1; 
symbol_ct*-  1; 


SIGNAL  FO_Error; 
Lost_Ct  •-  LMt_Ct  +  1; 


PH_Indication(symbol)  =  {  PAjHi-I**].  SDJJ.^T]  symbol  •-  symbol  +  1; 
}  A  (symbol  «=  SD,[K]) 


PH  Indication(8ymbol)  >=  {  PA, (I,. .1^,1.  (SD[J  A 
V  (SD(J]  A  PAJIJ)  } 


PH  Indication(8ymbol)  ^  {  Start  of  Frame 
Seqaeact  -  PA,a,..I«J,  SDJJ.K]  } 


PH_Iiidication(s]nnbol)  {  PA,[I,..Im], 
SD,[J,K],  FCJn,n]  }  A  (synibol  ^  FC,{nJ  a 
l£i^2) 


PH_Iiidication(8ymbol)  «  {  PAJI,..!^], 
SDXI>K]i  FC,(n,n]  }  A  (FC,  «  Frame) 


PH_Indication(symbol)  »  {  PA4I|«Ik1> 

SD,[J,K],  FC4n,n]  }  A  (FC,  —  Acknowledgment) 


PH_Indication(8ymbol)  =  {  PA,[I|..I«1,  SD[J,K1, 

PAJIJ) 


SIGNAL  Idle; 
symbol  •-  0; 
symbol  *-  symbol  +  1; 
8]rmbol_ct  0; 


symbol  •-  symbol  -l-  1; 
symbol  cl  •-  symbol_ct  + 
1; 


SIGNAL  PDU  Frame 


SIGNAL  PDU_Ack 


SIGNAL  Idle; 
symbol  *-  0; 
symbol  symbol  +  1; 
symboI_ct  0; 
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Tnnsitim 


Enabling  Predicate 


Action 


Format  Error 
on  FC 
R(3-l); 


Tdcen 

R3-T0; 


Subtoken 

R3-S0; 


Receive  DA 
symbols 
F(0-0); 
A((W)); 


DA  Match 
FO-Rl; 


Strip  on  DA 

FO-Rl; 

AO-Rl; 


Format  Error 
on  DA 
FO-Rl; 
AO-Rl; 


PH  Indication(symbol)  =  {  PAJ,..I^], 
SDjj,K].  {-^PAJIJ  V  -^FC/n.nJ)  } 


PH  Indicati<Hi(symbol)  =  {  PA^, 
Sd5j,K1.  FQn,nl  }  A  (FC,  =  Token) 


PH_bulication(symbol)  =  {  PA,ni*>lK]t 
SD,IJ,K].  FCJn,n]  }  A  (FC,  =  Subtoken) 


PH_Indicati<m(8ymbol)  =  {  PA,P,..I_], 
SdJj.K],  FC,ln,n].  DAJ4n  V  12nJ  }  A  (symbol 
«  DA,[nj9  1^1^12) 


PH_Indication(symbol)  =  {  PA,a, SD[J.K1, 
FCJn,n],  DAJ4n  V  12n]  }  A  [(FC,X  =  0)  A 
(DA,  €  {SSA})]  V 
f(FC,.L  =  1)  A  (DA,  e  {SLA»1 


PH  Indication(8ymbol)  =  {  PA,[I,..^.„],  SD[J,K], 

Fc2n.nJ.PA/rj} 


PH  Indication(symbol)  =  { 

SD2j.K].  FCJn.nl.  (^PAJIJ  V  -yDAJ4n  V 
12nJ)) 


DA  null  or  no  (DA,  null)  V  (DA,  €  {SSA})  V  (DA,  6 


DA  match 
F(0-17); 


Copy  Frame 
to  Local  Entity 
(LLC,  SMT, 
MAQ 
F(l-2); 


Set  Next 
Station 
Addressing 
Flag 

F(l-2); 


{SLA} 


SIGNAL  FO_Error; 
Lost_Q  •-  Lost_Q  +  1; 
symbol  *-  0; 

8yinbol_ct  •-  0; 


SIGNAL  PDU  Tk 


SIGNAL  PDU  SbTk 


symbol  •-  symbol  +  1; 
symbol_ct  *-  symbol_ct 


A_Flag  •-  set; 


SIGNAL  Idle; 
symbol  •-  0; 
symbol  symbol  +  1; 
symbol_ct  •-  0; 


SIGNAL  FO_Enor; 
Lost_Q  L^_Ct  +  1; 
symbol «-  0; 
s3anboI_ct  0; 


Copy_Frame  true; 
SIGNAL  FR_Strip; 


A_Flag  A  (FC,  »  Next  Station  Addressing 
Frame) 


N_Flag  •-  set 


1  Tnmsitioa 

Enabling  Predicate 

Action 

Receive_Cp 

SA  Symbols 
F(2-2); 

A(l-l); 

PH  Indication(symbol)  =  {  PA,[I|..Ik], 

SDij,K],  FC,In.n].  DAJ4n  V  12nl. 

SAJ4n  V  12n]  }  A  Copy  Frame  A  (symbol  = 
SAJnJ  s  1^1^12) 

Rcv-buf(symbol)  *- 
PH_Indication(symbol) ; 
symbol symbol  +  1; 
symbol  ct  *-  symbol  ct  + 

1; 

Higher  SA 
F(2-3); 

F(17-18); 

A(l-2); 

A(4-5); 

[(FC,.L  =  0)  A  (SA,  >  MSA)  A  MLA  =  0]  A 
[(FC,.L  =  1)  A  (SA,  =  MLA)] 

H_Flag  *-  set; 

Lower  SA 
F(2-3); 

F(17-18); 

A(l-2); 

A(4-5); 

[(SA,  >  0)  A  (FC.L,  =  0) 

A  (SA,  <  MSA)  A  (MLA  =  0)] 

V  [(FC,.L  =  1)  A  (SA,  <  MLA)] 

L_Flag  •-  set; 

MySA 

F(2-ll); 

[(FC.L,  =  0)  A  (SA,  =  MSA)  9  MSA  >  0]  V 
I(FC.L,  =  1)  A  (SA,  =  MLA)  9  MLA  >  0] 

M_Flag  *-  set; 

Strip  on  SA 
F(f)-Rl; 

Al-Rl; 

f=2.17; 

PH_Indication(symbol)  =  {  PA,[I|..I_],  SD[J,K], 
FCin,n],  DA,[4n  V  12n], 

PAJIJ) 

SIGNAL  Idle; 
symbol  •-  0; 
symbol  •-  symbol  +  1; 
symbol_ct  *-  0; 

Format  Error 
on  SA 

F(0-Rl; 

Al-Rl; 

f-2,17; 

PH  Indication(symbol)  =  {  PA,n,..U.], 

SDi(J,K].  FC,In.n],  DAJ4n  V  12n],  {-'PAJIJ  V 
-'SAJ4n  V  12nJ)  } 

SIGNAL  FO_Error, 

Lost_Ct  •-  LTOt_Ct  +  1; 
symbol  •-  0; 
symbol_ct  •-  0; 

Receive_Cp 
INFO  8]rmbols 
F(3-3); 

F(13-13); 

PH  Indication(symbol)  =  {  PA  n,  ,  1. 

SDJJ.K],  FCJn,n],  DAJ4n  V  12n], 

SA,(4n  V  12n],  INFOJn,..n^  }  A  C<^y_Frame 

A  (s]rmbol  «  INFO,(nJ  a 

Rcv-buf(symbol)  •- 
PH_Iiidication(symbol) ; 
symbol  symbol  +  1; 
symbol  ct  •-  symbol  ct  + 

1; 

Strip  on  INFO 

F(f)-Rl; 

f-3,11,18, 

24; 

PH_Indication(s]rmbol)  =  {  PA,[I|..I»,1,  SD[J,K], 
FC,[n,n],  DAJ4n  V  12n],  SA,(4n  V  12n], 

PAJIJ) 

SIGNAL  Idle; 
symbol  •-  0; 
symbol  •-  symbol  +  1; 
8ymbol_ct  *-  0; 

Format  Error 
on  INFO 
F(f)-Rl; 
f-3, 11,18, 

24; 

PH_Indication(8ymbol)  =  {  PA,p,..I^l. 

SOjj.K],  FCJn,n],  DA,(4n  V  12n],  SA,(4n  V 

I2a],  {-'PAJIJ  ->INFOJn,..n^  } 

SIGNAL  FO_Enor; 

Lost_Ct  L^_Ct  +  1; 
symbol «-  0; 
symbol_ct  •-  0; 
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Tfinsitioa 

Enabling  Predicate 

Action  1 

DA-MA 

LLCorSMT 

Fnune 

withSbtk 

F(3-4); 

(FC,  =  LLC  Frame  with  subtoken  V 

FC,  B  SMT  Frame  with  subtoken)  A  A_Flag  A 
~'E_Flag  A  (L_Flag  V  H_Flag) 

SIGNAL 

My  DA  LLC  or 
SMT_wiUi_Sb'i; 

DA-MA 

LLC  wSMT 
Fnune 
without  Sbtk 
F(3-4); 

(FC,  B  LLC  Frame  without  subtoken  v 

FC,  SMT  Frame  without  subtoken)  A  A_Flag 

A  ”'E_Flag  A  (L_FIag  V  H_Flag) 

SIGNAL 

My_DA_LLC_or_ 

SMT_witbout_Sbtk; 

Strip  on  FCS, 
ED 

F(f)-Rl; 

f-4.12,19. 

25; 

PH  IndicatitmCsymbol)  =  {  PA,[I, SD[J,K], 
FCi(n.n].  DA,[4n  V  12n].  SA,{4n  V  12n], 
INFOJn,..n«J.  PAJIJ  } 

SIGNAL  Idle; 
symbol  •-  0; 
symbol  *-  symbol  +  1; 
symbo)_ct  •-  0; 

Format  Emn’ 
on  FCS,  ED 
F(f)-Rl; 
f-4.12.19, 

25; 

PH  Indication(symbol)  «  {  PAJI,..I^], 

SdIj.K].  FC,(n.n].  DA,(4n  V  12n].  SAJ4n  V 

12n],  INFOJn,,.n«J,  (-'PAJIJ  V  ->FCSJ8nJ  V 
-'EDJTD  } 

SIGNAL  FO_Errur, 

Lost_Ct  ♦-  Lost_Ct  +  1; 
symbol  ••  0; 
symbol_ct  •-  0; 

ED 

Received 

Cp 

¥(4-5); 

F(12-13); 

Rcv-buf(symbol),  PH  Indication(8ymbol)  «  { 
PAJI,..U].  SD,IJ.Ki;  FC4n,nl.  DA,l4is  V  12n], 
SAJ4n  V  12nl,  INFO,tn|..nJ,  FCSJSn], 

EDXn} 

Frame  Ct^Frame  Ct 
+  1;  ~ 

Receive 
Detennine  FS 
Symbols 
¥(5-5); 

PH  Indication(symbol)  «  {  PA,(IflMl> 

SDjj,Kl.  FC,(n,n],  DAJ4n  V  12nl, 

SAJ4n  V  12n],  INFO,(n,..nJ,  FCSJSn], 

EDjn,  FS.EJS/RJ.  FS.AJS/RJ,  FS.CJS/RJ  }  A 
Copy  Fnune  A  (syiidml  »  (FS.E,(S/R]  A 
FS.AJS/R]  A  FS.CJS/R])) 

Rcv-buf(s}rmboI)  •- 
PH_Indicatioo(qrmbol); 
symbol «-  sjrmbol  +  1; 
sjrmbol  ct  •-  sjmibol  ct  + 

I; 

Invalid 

F(5-6); 

F(13-14); 

F(20-21); 

F(26-27); 

PH_InvaUd 

SIGNAL  FR_Received; 
Copy_Franie  «-  hdse; 

Fr_Strip  *-  off; 

Valid  Frame 
F(5-7); 

F(13-15); 

F(20-22); 

F(26-28); 

[(FS.E,  «  R)  A  (Valid  Data  Length)]  V 
[(Valid  FCS,)  A  (FC,.FF  -  Iiqilementor)] 

TVX- Reset; 

E_Flag  •-  clear; 

Valid_Ffame  •-  true; 
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I'nantiao 


Enibling  Predicate 


Action 


Ack  Frame 
F(8-9); 

FS.A,  *  R  A  C_Flag 

. 

N_Flag  ♦-  clear;  SIGNAL 
Ack_Ftame; 

No  Ack  Frame 
F(8-9); 

FS.A,  r*  R  A  N_Flag  v  -’(C_Flag) 

Ack_Ftame  •-  off; 

Suspected  DA 
Reoeived 

F(8-9); 

(FS.A,  -  S)  A  (A_Flag)  A  (DA,.IG  =  0)  A 
-i(E_Flag)  A  (FC,TfF  =  0) 

Notify_SMT(su8pected 

DA_received) 

LLCorSMT 
Frame  widi 
DA-MA 
Received 
F(9-10); 

PH  Indicatioo(8]mdml)  -  (  PA,P,..I^], 

SDjj.Kl.  FCJn.n].  DAJ4n  V  i2a]. 

SAJ4n  V  I2n],  INFOJn,..iuJ,  FCS^Snl. 

EDXn.  FS.E,(S/R1,  FS.AJS/Rl,  FS.C,fS/RJ  }  A 
(FC,  “  LLC  Frame  V  FC,  =  SMT  Frame)  A 
-<(E_Flag)  A  A_Flag 

R  Flag  «-  clear; 

SIGNAL  FR_Received; 
Copy_Frame  *-  Bdse; 

Fr_Strip  •-  off; 

My  Void 
F(1M2); 
F(24-25); 

(FC,  -  Void)  A  (A_Flag)  A  (M_Flag) 

TVX  •-  reset; 

SIGNAL  My_Void; 

My  MAC 

Claim 

Token  Bid 
F(U-12); 

(FC,  »  Claim)  A  (A_Flag)  A  (M_Flag)  A 
(T  Max  ^  T  Bid  Rc  ^  T  Min)  A  (T  Bid  Rc 
-  T_Roq) 

SIGNAL  My  Claim; 

T_Neg  -  T_Bid_Rc; 

Receive  Cp 
FCS,  ED 
Syadmis 
F(12-12); 

PH  Indication(symbol)  «■  {  PA,ni'‘lM]> 

SDiij.K].  PCJn.nl.  DAJ4n  V  12a]. 

SAJ4n  V  I2nl,  INFOJn,..iuJ.  FCSJSnJ,  EDflJ 
}  A  Copy  Frame  A  (symbol  »  FCSJnJ  » 
l</i8)  ‘ 

Rcv-bufCsymbol)  •- 
PH_Indicatioo(s3niiboI); 
sjmdml  •-  s3nidiol  ■(-  1; 
symbol  ct  •-  symbtd  ct  + 

1;  " 

Receive  Q) 
FSSyn^ 
F(13-13); 

PH  IndicatkMi(s)redxd)  -  {  PAJI,..I^]. 

SDIj.K].  FCJn.nl.  DAJ4n  V  12nl. 

SAJ4n  V  12a].  INFOJn,..n^.  FCSJ8n]. 

EDjn,  FS,EJSmj.  FS.A/S/RJ.  FS.CJ5/RJ  }  A 
Co^  Frame  A  (symbol  -  (FS.EJS/R]  A 
FS.AJS/R]  A  FS.CJS/R])) 

Rcv-baf(8]rmboI)  «- 
PH_Indication(8yinbol); 
qrmlad  «- sjrmbol  +  1; 
symbol  ct  •-  S3aDbol  ct  -f 

1; 

My  MAC 

Claim 

Received 

F(15-16); 

PH  lndication(synd>ol)  »  {  PAJI,..Im]. 

SDjj.Kl.  FCJn.nl.  DAJ4n  V  12nl. 

SAJ4n  V  12nl.  INFOJn,..iuJ.  FCSJ8nl. 

EDjn,  FS.EJS/Rl.  FS.AJS/R1.  FS.CJS/R]  }  A 
(Vidid_FfamB)  A  (My_Cli^) 

T_Neg  ♦-  T_Bid_Rc; 

SIGNAL  FR_Received; 
Copy_Frame  fidse; 

Fr_Strip  •-  off; 

My_Claim  •-  off; 

Receive  SA 
Symbola 
F(17-17); 
A(4-4); 

PH  bidicatiao(symbol)  >  (  PA,n,.-I^„)- 
SDjj.iq,  FCJn.nl,  DAJ4n  V  12nl, 

SA/4h  V  I2hJ  }  A  (s)mibol  ~  SAJnJ  » 

B]niibol  •-  syndwl  +  1; 
qrmbol  ct  •-  S3ranboI  ct  + 

1;  " 
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Tniuitioa 


Enabling  Predicate 


Action 


My  SA  F(17- 
24); 

I(FC.4  =  0)  A  (SA,  =  MSA)  a  MSA  >  0]  V 
((FC.L,  =  1)  A  (SA,  =  MLA)  3  MLA  >  0] 

SIGNAL  Fr_Strip; 

M_Flag  •-  set; 

Receive  INFO 
symbols 
F(18-18); 
F(24-24); 

PH  Indication(8ymbo))  =  {  PA,[I,..I„1, 

SdJj.K].  FCJn,n],  DAJ4n  V  12nl. 

SAJ4n  V  12n],  INFOJn,..n^  } 

symbol  •-  symbol  +  1; 
symbol  ct  *-  symbol  ct  + 

1; 

Higher  MAC 
Claim 

TkBid 

F(18-19); 

(FC,  =  Claim)  A  (H_Flag)  A 

(T_Max  ^  T_Bid_Rc  T_Min)  A  (T_Bid_Rc 

>  T_Req) 

SIGNAL  Higher_CIaim; 
T_Neg  •-  T_Bid_Rc; 

Upstream 

MAC  Beacon 
F(18-19); 

(FC,  »  Beacon)  A  ~'(M_Flag) 

SIGNAL  Other  Beacon; 
T_Neg  -  T_Max; 

Ijower  MAC 
Claim 

TkBid 

F(18-19); 

(FC,  =  Claim)  A 

-•[(H  Flag)  V  (M  Flag)]  A 

{[(MSA  enabled)  3  (MSA  >  0)]  V 

[(MLA  enabled)  3  (MLA  >  0)]}  A 

(T_Max  ^  T_Bid_Rc  ^  T_Min)  A  (T_Bid_Rc 

<~T_Req) 

SIGNAL  Lower_Claim; 

T_Neg  •-  T_Bid_Rc; 

Other  DA 
LLCorSMT 
Frame  F(18- 
19); 

(FC,  ■  LLC  Frame  v  FC,  »  SMT  Frame)  A 
~'(E_Flag)  A  (L_Flag  V  H_Flag) 

SIGNAL 

Othcr_LLC_or_SMT; 

ED  Received 

F(  19-20); 
F(25-26); 

PH_Indication(8ymbol)  =  {PAJI.-.IJ.  SDJJ.K], 
FCJn,n],  DA,(4n  V  12n],  SA,[4n  V  12n], 
INFO,(n,..n«J.  FCSJSn],  EDXH} 

Frame  Ct^Frame  Ct 
+  1;  " 

Receive  FS 
Symbols 
F(20-20); 
F(20-26); 

PH  Indication(8ymbol)  -  {  PA,[I, 

SDjj,K],  FCJn,nl.  DA44n  V  12nl, 

SAJ4n  V  12n],  INFO,[n,..nJ,  FCSJ8n], 

EDJT].  FS.EJS/RJ.  FS.A/S/RJ,  FS.CJS/R]  }  A 
(symbol  *  (FS.E,{S/R]  A  FS.A,{S/R]  A 
FS.CJS/RD) 

83rmboI  •-  s3rmbol  +  1; 
symbol  ct  •-  s3rmbol  ct  + 

1; 

Other  DA 

LLCorSMT 

Frame 

Received 

F(22-23); 

PH  IndicatkxKsymbol)  »  {  PA4I|..I»]> 

SDij,K],  FC,In,n],  DAJ4n  V  12nl, 

SAJ4n  V  12nl,  INFO,[n,..ii«J,  FCSJSnJ, 

EDXn.  FS.EJS/R],  FS.AJS/R],  FS.C,(S/R]  }  A 
(Valid_Fnme)  A  (Other_LLC_or_SMT) 

SIGNAL  FR_Received; 

Other  LLC  or  SMT  *- 
off; 
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Tnuisiti<m 


Enabling  Predicate 


Action 


Higher  MAC 
Claim 
Recmved 
F(22-23); 

Lower  MAC 
Claim 
Received 
F(22-23); 


Upstream 
MAC  Beacon 
Received 
F(22-23); 


My  Beacon 
F(24-2S); 

My  MAC 
Beuon 
Received 
F(28-29); 

DA  Match 
AO-Rl; 


Receive_Cp 
ED  Symbol 
A(2-2); 


Strip  oo  ED 

A(2-l); 

A(5-l); 


F<»mat  Error 
on  ED 
A(2-i); 
A(5-l); 


PH  Indication(8ymbol)  =  {  PA,[I, ..!„], 

SDJJ.K].  FCJn.n].  DAJ4n  V  12nl, 

SAJ4n  V  12n].  INFOJn,..n_J,  FCSJ8n], 

EDjn.  FS.EJS/R],  FS.AJS/R].  FS.CJS/R]  }  A 
(Valid_Frame)  A  (Higher_Claim) 

SIGNAL  FR_Reccived; 
Higher_Claim  *-  off; 

PH  Indication(symbol)  =  {  PA^,..I^], 

SDJJ,K].  FC^n.n].  DAJ4n  V  12n], 

SA^4n  V  12n],  INFOJn,..n _ 1.  FCSJ8n], 

EDjn.  FS.E,[S/R],  FS.AJS/R],  FS.CJS/R]  }  A 
(Vtiid_Frame)  A  (Lower_Claim) 

SIGNAL  FR_Received; 
Lower_Claim  *-  off; 

PH  Indication(symbol)  =  {  PA^, 

SDJJ,K1.  FCJn.n],  DAJ4n  V  12n], 

SAJ4n  V  12n].  INFOJn,..n_J,  FCSJ8n], 

EDXn.  FS.E,[S/R].  FS.AJS/R].  FS.CJS/R]  }  A 
(Vidid_Frame)  A  (C>ther_Beacon) 

SIGNAL  FR_Received; 
Other_Beacon  off; 

(FC,  =  Beacon)  A  (M_Flag) 

SIGNAL  My_Beacon; 

T_Neg  T_Max; 

PH  Indication(8ymbol)  =  {  PA,P,..I^], 

SDJJ,K1,  FC^n.n],  DAJ4n  V  12n]. 

SAJ4n  V  12nl.  INFOJn,..nJ,  FCSJ8nl, 

EDXn.  FS.E,[S/R],  FS.AJS/R],  FS.C,[S/R]  }  A 
(Viiid_Frame)  A  (My_Beacon) 

SIGNAL  FR_Received; 
My_Beacon  off; 

PH  IndicationCsymbol)  ==  {  PA^,..I^].  SD[J,K], 
FCin,n],  DA^4n  V  12nl  }  A  [(FC,.L  =  0)  A 
(DA,  €  {SSA})]  V 
[(FC,.L  =  1)  A  (DA,  €  {SLA})] 

A_Flag  •-  set; 

Copy  ack  *•  true; 

SIGNAL  FR_Strip; 

PH  Iiidication(symbol)  >=  {  PAJ[I, ..!_], 

SDjj,K],  FCJn,nl,  DAJ4n  V  12n], 

SA,[4n  V  12iiJ,  EDJT] }  A  Copy_FrBme  A 
(symbol  =  EDJT]) 

Rcv-buf(symbol)  «- 
PH_Indication(symboI); 
symbol  •-  symbol  +  1; 
symbol  ct symbol  ct  + 

1;  " 

PH_Indicatioa(8ymbol)  =  {  PAJI, SD[J,K], 
FCJn,n],  DAJ4n  V  12n],  SAJ4n  V  i2n], 

PAJIJ) 

SIGNAL  Idle; 

S3rmbol  •-  0; 
symbol  symbol  +  1; 
8ymbol_ct  ^  0; 

PH_Iiidicatioo(8ymbol)  {  PA,P,..I^], 

SDj[j,K],  FCJn,n],  DAJ4n  V  12n],  SAJ4n  V 

12n],  (->PAJIJ  V  ^EDJTD  } 

SIGNAL  FO_Error; 

Lo8t_Ct  •-  Lo«t_Ct  +  1; 
symbol  0; 
symbol_ct  0; 
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Tnmsition 


Enabling  Predicate 


Action 


ED  Rcv-buf(synibol),  PH  Indication(symbol)  =  { 

Received,  PA^,..IJ,  SDJJ.KL  FQn,n],  DA,[4n  V  12n], 
Cp  SAJ4n  V  12n],  ED^T]  } 

A(2-3); 


Receive  Cp  Rcv-buf(synibol),  PH  Indication(synibol)  =  { 

FS  Symbols  PAJI,..IJ,  SDJJ.Kf,  FCJn,nl,  DA,[4n  V  12n], 

A(3-3):  SAJ4n  V  12n],  EDJT].  FS.EJS/RJ.  FS.AJS/R], 

FS.CJS/R]  }  A  Copy_Ack  A  (symbol  = 
(FS.EJS/R]  A  FS.A,[S/R1  a  FS.CJS/R])) 


My  LLC  or  PH_Indication(symbol)  =  {  PA,|1, 

SMT  Frame  SDJJ.K],  FCJn,n],  DAJ4n  V  12n], 

Ack  Received  SAJ4n  V  12n],  EDJTl,  FS.EJS/R],  FS.AJS/R], 
A(3-l);  FS.CJS/R]  }  A 

(FC,  =  LLC_Frame_Ack  V 
FC,  =  SM^_Frame_ack)  A  M_Flag 


PH  Indication(symbol)  =  {  PAJI,..^],  SD[J,K], 
FCjn,n].  DAJ4n  V  12n],  SAJ4n  V  12n], 
EDjn,  PAJIJ  } 


PH  Indication(symbol)  =  {  PA,[I,..l,^], 
SDjj,K],  FCJn,n],  DAJ4n  V  12n],  SAJ4n  V 
12nl,  EDjn  V  -^(FS.EJSmj,  V 

FS.A/S/RJ.  V  FS.C/S/RJ))  } 


no  DA  match  (DA,  «  nuU)  V  (DA,  (E  {SSA})  V  (DA,  e 
A((M);  {SLA} 


Receive  ED  PH  Indicatioa(symbol)  ^  {  PAJI, ..!_], 

Symbol  SDjj,K],  FCJn,n],  DAJ4n  V  12n], 

A(5-5);  SAJ4n  V  12nl,  EDJT]  }  A  (symbol  =  ED,[T|) 


ED  Received  PH  Indication(symbol)  «  {  PA,(T,..T^,]. 
A(5-6);  SDjj,Kl,  FCJn,n],  DAJ4n  V  12nl,  SAJ4n  V 

12n],  EDJT]  } 


Receive  FS  PH_Indication(symbol)  «  {  PAJI,..I^], 
Symbols  SDJJ,K],  FCJn,n],  DAJ4n  V  i2o], 

A(6^);  SAJ4n  V  12n].  EDJT],  FS.EJS/RJ.  FS.A/S/RJ, 

FS.CJS/RJ)  A  Copy  Ack  A  (symbol  « 
(FS.EJS/R]  A  FS.AJS/R]  A  FS.CJS/R])) 


Ack_Ct  *-  Ack_Ct  +  1; 


Rcv-buf(symbol)  *- 
PH_Indication(symbol); 
symbol  •-  symbol  +  1; 
symbol_ct  •-  symbol_ct  + 
1; 


SIGNAL  Ack_Received; 
Copy_Ack  false; 
FR_Strip  •-  off; 


SIGNAL  Idle; 
symbol  *-  0; 
symbol  •-  symbol  +  1; 
8ymbol_ct  *-  0; 


SIGNAL  FO_Error; 
Lost_Ct  Lost_Ct  +  1; 
symbol  •-  0; 
symbol_ct  0; 


symbol  •-  symbol  +  1; 
8ymbol_ct  *-  symbol  ct  + 
1; 


Ack_Ct  •*  Adc_Ct+ 1; 


symbol  •-  symbol  +  1; 
8ymbol_ct  8ynibol_ct  + 
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Tnnsitioa 

F-nshling  Predicate 

Action 

Other  LLC  or 
SMT  Frame 

Adc  Received 
A(3-l); 

PH  Indication(symbol)  =  {  PA^,..I^], 

SDJJ,K],  FQn,n].  DAJ4n  v  12nl. 

SAJ4n  V  12nl,  EDJT].  FS.EJS/Rl,  FS.AJS/R], 

FS.QS/R1  }  A 

(FC,  =  LLC_Frame_Ack  V 

FC,  =  SMT_Frame_ack)  A  -•(M_Flag) 

SIGNAL  Ack  Received; 

’ 

Receive  Sbtk 
Symbols 

S(0-0); 

PH  Itulicati<Hi(symbol)  =  {  PA^Oi-U*  SDJJ.K], 
FQCLFF.ZZZZ],  SLJ4n  V  I2nJ.  ELJ4n  or 

12nJ.  CLASSJln], 

EDJT.n  }  A  (symbol  =  SL^nJ  > 

symbol  •-  symbol  +  1; 
symbol  ct «-  symbol  ct  + 

1;  ” 

Strip  on  Sbtk 

1  SO-Rl; 

PH  Indication(symbol)  =  {  PAJI, SD[J,K], 
Fcin,n].  PAJIJ  }  V 
{  PAJI,..U1.  SD[J.K1.  FQn,nl, 

SI44n  V  12nl,  PA/IJ  }  V 
{  PAJI,..U].  SD[J.K].  FQn,n], 

SI44n  V  12nl,  ELJ4n  or  12nl,  PAJIJ  }  V 
{  PA,(I,..U1,  SD(J.K1.  FQn,nl, 

SI44n  V  12nl.  ELJ4n  or  12n].  CLASSJ2n], 
PAJIJ) 

SIGNAL  Idle; 
symbol  •-  0; 
symbol  •-  symbol  +  1; 
symbol_ct  •-  0; 

Format  Error 
on  Sbtk 

SO-Rl; 

PH  Indication(8ymbol)  -  {  PA^i..Im],  SD[J,K], 
FCjn.nl,  {-'PAJIJ  V  ->SL/¥#i  V  12nJ)  }  V 
{  PA,n,..Ul»  SD1J.K],  FC.[n,nl. 

SLJ4n  V  12nl,  (-'PAJIJ  V  -^ELJ4n  V  I2nJ)  } 

V 

{  PAJI...U1.  SD[J,K],  FC.[n,nl. 

SI44n  V  12nl,  EIJ4n  or  12nl,  (-'PAJIJ  V 
-'CLASSJ2nJ)  }  V 
{  PAJI,..U1.  SD[J,K].  FCin,nl. 

SI44n  V  12n],  ELJ^  or  12n],  CLASS.(2nl, 
(-•PAJIJ  V  ->EDJT.T7)  } 

SIGNAL  FO_Error; 

Lost_a  •>  LMt_a  +  1; 
symbol  •-  0; 
symbol_ct  •-  0; 

My  Address 
Widiin  Sbtk 
Limits 

S(0-1); 

SL,  ^  MA  <:  EU 

SbTk  Flag  «-  Set; 

Write  SbTk_Cla8s; 

My  Address 
not  Within 

SbTk  Limits 
S(0-1); 

(MA  <  SL,)  V  (MA  >  EL,)  V  (SL,  <  EL,) 

SbTk_FIag  •-  Reset; 

TVX*- Reset; 

Subtoken 

Received 

Sl-Rl; 

PH  Indication(symbol)  -=  {  PA,(I,..1J,  SDJJ.K1. 
FCiCLFF.ZZZZ].  S144n  V  12a],  E144a  or 

12n].  CLASS,(2n], 

ED  jr.T]  } 

SIGNAL 

SbTk_Received; 
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Tnnsitioo 

Enabling  Predicate 

Action 

RecMve  Tk 
Symbok 

T(0-0); 

PH  Indication(symbol)  =  {  PA,[I,..IJ,  SDJJ.K], 
FcjCLFF.ZZZZl,  EDJT.7]  }  A  (symbol  = 
EDJT,]) 

8ymbol  •-  8ymbol  +  1; 

8ymbol  ct  *-  8ymbol  ct  + 

1; 

Strip  on  Tk 
TO-Rl; 

PH  Indication(8ymbol)  =  {  PAJI, SD[J.K], 
FQn.nl.  PAJIJ } 

SIGNAL  Idle; 

8ymbol «-  0; 

8ymbol  *-  8ymbol  +  1; 
symbol_ct  0; 

Format  Error 
on  Hr 

TO-Rl; 

PH  Indication(symbol)  =  {  PAJI,..!.,].  SD[J.K]. 
FQn.nl.  V 

■^EDJT.W  } 

SIGNAL  FO_Enor; 

Lost_Ct  •-  Lo8t_Ct  +  1; 
8ymbol «-  0; 

8ymbol_ct  *-  0;  | 

Non 

Restricted 

Tcdren 

T(0-1); 

PH  Indicati(Mi(symbol)  -  {  PA,[I,..I...„1. 

SDJj.K1.  FQn.nl.  EDJT.n  }  A 
(FC.C,  ^  Ncmrestricted) 

R_Flag  •-  Clear; 

TVX  •-  Reaet; 

Restricted 

Token 

T(0-1); 

PH  Indication(synibol)  =  {  PAJI|..Ia„l. 

SD.(J.K1.  FQn.nl.  EDJT.Tl  }  A 
(FC.C,  «  Restricted) 

R_Fkg  *-  Set;  | 

Token 

Received 

Tl-Rl; 

PH  Indication(8ymbol)  =  {  PAJI|..U.  SD,{J.K1. 
FCln.nl.  EDXT.n  } 

SIGNAL  Tk_Received;  | 
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5.  Mac  Transmitter  Operation  and  Specification 

The  Mac  transmitter  repeats  symbols  from  other  stations  over  the  ring  after 
a  station  delay,  and  transmits  its  own  symbols  which  come  from  the  appropriate  buffers. 
The  transmitter  operates  on  the  input  symbol  stream  from  PHY  (PHJndication)  and 
produces  the  output  symbol  stream  to  PHY  (PH_request).  Its  operation  is  synchronized 
by  signals  from  the  Receiver.  The  Transmitter  repeats,  removes,  and  inserts  a  PDU  into 
the  ring  during  different  phases  of  protocol  operation.  It  is  responsible  for  capturing  of 
a  token  or  subtoken,  carrying  out  the  timed  token  operations,  transmitting  data  and 
issuing  a  new  token.  The  transmitter  is  also  responsible  for  transmission  of  MAC 
supervisory  frames  in  the  recovery  and  beacon  processes. 

In  this  protocol,  the  MAC  of  the  tokra  holding  station  controls  the  transmission  of 

new  frames  and  token  on  the  dual  ring  by  using  a  Waitpn^  and  Wait _ variable 

set  by  each  transmitter  on  the  appropriate  ring.  When  a  transmitter  is  active  (i.e., 
transmitting  its  data)  the  Widt  variable  on  that  ring  is  set  to  true.  Upon  completion  of 
frame  transmission  this  variable  is  set  to  false. 

a.  Th€  MAC  Transmitter  State  IHagram  and  Transition  Table 

Figure  36  depicts  the  overall  view  of  the  MAC  Transmitter  State 
Diagram.  It  shows  1 1  smaller  diagrams  which  are  presented  as  separate  figures.  The  Idle 
state  is  shown  in  Diagram  1  (central  rectangle  in  Figure  36).  The  Idle  state  is  the  initial 
state  and  indicates  the  normal  condition  of  the  medium.  The  transition  7k  Idle  Symbols 
corresptmds  to  the  transmission  of  PDU  Preambles  (PA).  Several  examples  on  the 
transmitter  protocol  operation  are  given  in  this  subsection. 
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(1)  The  DA  Station  Removes  a  Frame  Being  Received  -  no  subtoken 


issued 


A  path  of  transitions  for  a  frame  without  subtoken  received  with 
a  DA  match  is  shown.  The  frame  is  removed  from  the  ring  and  no  subtoken  is  issued. 
The  path  begins  in  Diagram  1,  goes  through  Diagrams  2  and  3,  and  returns  to  Diagram 
1. 


•  10  7k  Idle  Symbols  10  Start  PO  Tx  Next  SD  Symbol  PO  SFS  Transmitted  PI  Frame 
FO  DA  Match:  Frame  Without  Subtoken  Strip  Frame  10  Tx  Idle  Symbols  10 


(2)  The  DA  Station  Receives  a  Frame  With  Subtoken  and  Uses  the 


Subtoken 


The  frame  with  subtoken  is  received  with  a  DA  match  and  the 
station  uses  the  subtoten  to  transmit  one  synchronous  or  asynchronous  ftame. 


•  10  2k  Idle  Symbols  10  Start  PO  Tx  Next  SD  Symbol  PO  SFS  Transmitted  PI  Frame 
FO  DA  Match:  Frame  With  Subtoken  FI  Usable  Subtoken  10  7k  Idle  Symbols  10 
Usable  Subtoken  Received  S2  7k  Syn/Asy  Frame  Symbols  S2  End  Syn/Asy  S3 
Station  Holding  Sbtk  Tx  Completed  10  7k  Idle  Symbols  10 


(3)  A  Station  Repeats  the  Frame  Downstream  on  the  Ring 

A  complete  path  of  transitions  for  the  repeat  frame  protocol 
operation.  This  process  is  accomplished  when  there  is  no  DA  or  SA  match.  The  frame 
is  assumed  to  be  repeated  with  no  error  detected. 
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•  10  73c  Idle  Symbols  10  Start  PO  73c  Atecr  SD  Symbol  PO  SFS  Transmitted  PI  Frame 
FO  DA=0  or  No  DA  Match  F2  No  SA  Match:  Pass  Frame  F3  Repeat 
FC,DA,SA,INFO,FCS,ED  Symbols  F3  ED  Transmitted  F4  Reset  E  TS  Tx  FS 
Symbols  F5  Frame  Repeated  10  73c  Idle  Symbols  10 


(4)  Reliability  Maintained  When  Configuration  Changes  (THRU  to 

WRAP) 

Assume  that  (1)  the  network  configuration  changes  to  the  "Wrap 
mode"  (one  logical  ring)  due  to  a  serious  ring  failure,  and  (2)  the  frame  is  received  with 
a  SA  Match.  The  frame  is  removed  from  the  ring  by  the  SA  address  station  as  in  the 
original  FDDI  protocol.  The  improved  protocol  reverts  to  the  basic  FDDI  operation. 

•  10  73c  Idle  Symbols  10  Start  PO  73c  Next  SD  Symbol  PO  SFS  Transmitted  PI  Frame 
FO  No  DA  Match:  Wrap  Mode  F2  SA  Match:  Wrap  Mode,  Strip  Frame  10  73c  Idle 
Symbols  10 


(5)  A  Station  Captures  a  Token,  Performs  Simultaneous  Transmission, 
and  Issues  a  new  Token, 

A  complete  path  of  transitions  is  given  for  (1)  capturing  of  a  token, 
(2)  simultaneous  transmission  of  one  synchronous  ftame  on  both  rings,  and  (3)  after 
transmission  of  both  frames  the  token  is  issued.  The  frame  on  the  primary  ring  goes  with 
the  subtokra  infcmnation. 

•  (1)  10  73c  Idle  Symbols  10  Start  PO  73c  Next  SD  Symbol  PO  SFS  Transmitted  PI 
Token  TO  Ring  Opr  and  Token  Early  T1  Nonrestricted  T2  Usable  Token  T3 
Capture  Token  10  73c  Idle  Symbols  10  Q) 
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Tk  Syn  Frame  Symbols EO  (a) 


/ 

(2)  10  Usable  Token  Received  EO 

\ 

Tx  Syn  Frame  Symbols _ EO  (b) 

(a)  EO  Syn  Frame  With  Sbtk  hrfo  Issued  El  Station  Holding  Tk  Tx  Primary  Ring 
Completed  E9  Ring  Opr  ElO  Nonrestricted  Ell  Wait  Other  Ring  Ell 

. (3)Issue  Token  E12  Tx  Token  Symbols  E12 

token  issued  10  Tx  Idle  Symbols  10 


(b) . EQ^r  Frame  Without  Sbtk  Issued  El  Station 

Holding  Tk  Tx  Secondary  Ring  Completed  10  Tx  Idle  Symbols  10 
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Figure  36:  MAC  Transmitter  State  Diagram 
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MAC  TRANSMITTER  STATE  DIAGRAM 
D  i  ag  .  1 


Figure  37:  Transmitt^  Diagram  1 
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MAC  TRANSMITTER  STATE  DIAGRAM 


D  i  ag  .  2 


From  10  TX  IDLE 
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From  1 0  TX  I DLE 
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MAC 

Requested 
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MAC  Frame 
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No  OA  Match 
Pass  Acte 
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Subtd'en 


Unusable 

Subtoiean 


Repeat  Act; 
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Reset  Strip 


Recovery 


Repeat  Subtle 
I  Syntoo  I  s 


Recovery 
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Figure  38:  Transmitter  Diagram  2 
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MAC  TRANSMITTER  STATE  DIAGRAM 
D  i  ag  3 


CSEE  DIAG  2D 


TX  ItXi 


Figure  39:  Transmitter  Diagram  3 
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Figure  43:  Transmitter  Diagram  7 
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MAC  TRANSMITTER  STATE  DIAGRAM 
D i ag .  1 □ 


CSEE  DIAG 


TX 

iU 

Figure  46:  Transmitter  Diagram  10 
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MAC  TRANSMITTER  STATE  DIAGRAM 


D i ag .  1 1 


From  lO  TX  IDLE 


<*SET  entry 


IDLE 


Figure  47:  Transmitter  Diagram  11 


Table  4  is  The  MAC  Transmitter  Transition  Table.  Transmitting  symbols 
transitions  show  the  cabling  predicate  with  the  current  contents  of  the  PH_request  buffer 
and  the  currrait  position  of  the  "symbol"  pointer  on  the  array  of  symbols  of  this  buffer. 


TABLE  4:  MAC  TRANSMTITER  TRANSITION  TABLE 


Tnmsitioa 

Bnahling  Predicate 

Action 

Tx  Idle  syndMls 
1(00): 

Txjdle 

PH.feque8t[symbol]  *- 

symbol*- 1,; 
symbol  *-  symbol  +  1; 

Reaet 

x-RO; 

x-I0.P0,Fl.F3, 

F5,A1,S1,T3,S2 

.E0,E3,E8.E12. 

IJ0.LS.L1.LS.M 

0.G0.O4.C2.CS 

.T7,B0; 

MAC_Reaet  V 

SM_MA_CONTROL.request(8etid_mac_fTame)  V 
{MAC_Fiaiiie  A 
[Ring_Operatioiial  V 

Lateja  »  0  V 

(Tokeo_Qas8  ^  nooe  A  -•My_Claim)]} 

T_Opr  •-  T_Max; 

TRT  *-  T_Opr, 

TokeQ_Cla8s  *-  none; 

Idle  •-  clear; 

Reaet_MAC 

requested 

RO-IO; 

MAC_Re8et 

Late_Ct  *-  clear; 
Ring_Opeiational  *-  clear; 

RewtMAC 
frame  received 
RO-IO; 

Riiig_Opefatioaal  V  Late_Ct  =  0 

T_Neg  •-  T_Max; 

■li_Idle  •-  set; 

Start 

lO-PO; 

Rc  Start  A  PH  Iiidicatioa(8ymboI)  ~ 

{  PAJI,..U1.  }  A  (symbol  -  SDJJ]) 

Idle*-  clear; 
PH_Reque8t(8ymbol)  *- 
PH_Iiidication(8ymbol); 
8]niibol  *-  symbol  -f  1; 

Tx  Next  SD 
symbol 

P(0O); 

PH.IndicatioiKsymbol)  -  {  PA^,..UJ,  SDJJ,K]  }  A 
(sjrmbcd  ^  SD,{K]) 

Tk_Idle  *-  clean 
PH_Reque8t(8ymbol)  *- 
PH_Indicatioo(symbol); 
s]rmbol  *-  83mibol  +  1; 

Strip 

x-IO; 

x-P0,F3,F5,Al 

.S1,T3; 

Idle  V  FR_Strip  V  FO__Error 

Tx_Idle  *-  set; 

SFS 

Tfansmitted 

P(0-1); 

PH_Reqoest(symbol)  -  {  PAJI,..IJ,  SDJJ,K1  }  A 
(symbol  «  SD  JK)) 

Tnnsitioii 


Enabling  Predicate 


Acti<Hi 


Frame 

Pl-FO 


Da  Match: 
Frame  with 
Subtokeo 
F(0-1); 


Uniuable  Sbtk, 
TxSbtk 
Syndmls 
F(l-1); 


Recovery 

x-CO; 

x-Fl,F3.F5,A 

l.Sl.T3,S2.E0. 

E3,E8.E12.IjO. 

LS.L1.LS.M0,G 

0,G4,C2.C5.T7 


Uaable  Subtoken 
Fl-IO; 


Sbtk  lasued 
Fl-IO; 


Da  Match: 
Frame  without 
Subtoken, 

Strip  Frame 
FO-IO; 


Da  Match: 
Wnp  mode 
F(0-1); 


Da  0  or 
No  DA  Match 
F(0-2); 


Void 

FO-IO; 


SA  Match: 
Strip  My  MAC 
Beecxm 
F2-I0; 


PDU  Frame 


(A_Flag)  A  (FCJn,n]  =  LLC  or  SMT  frame  with 
subtoken)  A  “’(Wrap) 


Sbtk.buf(symbol)  =  {  PA,[I,..I^1,  SDJJ.K],  FCJn.n], 
Sl^[^  or  12n],  El^[4n  or  12n],  CLASSJ2n], 
ED,[T„TJ  }  V  -'(Usable_Sbtk)  A  (symbol  = 
PA.[I,]); 


TVX  expired  V 

[TRT  expires  A  Late_Ct  >  0]  A 
Lower  Claim 


PH.requestlsymbol]  •- 
Subk-buf(symbol); 
symbol  *-  symbol  +  1; 


Tx  Idle  •-  set; 


PH  Reque8t(symbol)  =  {  PAJI,..IJ,  SDJJ,K1, 
FCjn.n],  SL.(4n  or  12n],  E4[4n  or  12nl.  CLASS.[2nl, 
}  A  (symbol  =  ED,[TJ) 


(A_Flag)  A  (FCJn,n]  =  LLC  or  SMT  frame  without  Tx_Idle  «-  set; 
subtoken)  A  ~>(Wrq>) 


(A_Flag)  A  (Wrq>) 


(DA4^  V  12n]  =  null)  A  -»(A_Flag) 


FCJn.n]  -  Void 


(DAJ4n  V  12n]  »  null)  A  (M_Flag)  V 
(FCjn,n]  K  Beacon  Frame) 


Tx  Idle  *-  set; 


Tx  Idle  set; 
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Tnnsitioa 

Pjiahling  Predicate 

No  SA  Match: 
Pass  Frame 
F(2-3); 

(M_Flag) 

Rq>eat  FC,  DA, 
SA,  INFO, 

FCS,  ED 

Symbols 

F(3-3); 

PH  Indication  =  {  PAJI,..U.l,  SDJJ,K],  FC,In,n], 
DAii4n  V  12n].  SAJ4n  V  12nl,  INFOJn,..iwl, 
FCSJSn],  EDjn  }  A 
(symbol  -  FC,{n,n]) 

ED  Transmitted 
F(3-4); 

PH.Request  =  {  PA,[I,..I«J.  SD,(J,K],  FC,[n,n], 

DA,[4n  V  12n],  SA,[4n  V  12n],  1^0Jn,..n^, 
FCSJSnl,  ED.rn  >  A 
(symbol  *  ED,[TJ) 

SetE 

F(4-5); 

PH  Indication(8ymbol)  =  {  PAJI,..U,  SDJJ,K1, 
FCj(n,n],  DAJ4a  V  12n].  SAi4n  V  12n], 

INFOJn,..n_J,  FCS,I8nl,  EDXT],  FS.EJS/R]  }  V 
(symbol  FS.E,[S/R])  A  (E_Flag) 

ReaetE 

F(4-5); 

PH  Indication(syinbol)  =  {  PA^Hi-U.  SDJJ,K], 
FCln,n],  DA,[4n  V  12nl,  SA,[4n  V  i2n], 

INFO,(n,..n«J,  FCS/Sn],  EDjn.  FS.EJS/R]  }  V 
(83rmbol  «=  FS.EJS/R])  A  ~’(E_Flag) 

Tx  FS  Symbols 
F(5-5); 

PH  Request  »  {  PA.(I,..U,  SDJJ,KJ,  FC.[n,n], 

DA.(4n  V  12o],  SA.(4o  V  12o],  INFO.[n,..iiuJ, 
FCS,(8nl,  EDjn.  FS.PtS/R],  FS.A,[S/R1,  FS.CJS/RJ 
}  A 

(symbol  ED,ni) 

Frame  Repeated 
F5-I0; 

PH.Request  -  {  PAJI,..IJ,  SDJJ.K1,  FC.ln,nl, 

DAJ4n  V  12nl,  SA.(4n  V  12nJ,  INFOJn,..n,J, 
FCSJSnJ,  EDJT],  FS.E*IS/RJ,  FS.AJS/R],  FS.CJS/R] 

}  A 

(symbol  -  FS.CJS/R] ) 

Ack 

Pl-AO; 

PDU_Ack  A  ”»(Wrap) 

DA  Match 

AO-IO; 

A.Flag 

No  DA  Match: 
Pass  Ack 

A(0-1); 

-'(A_FIag) 

Repeat  Ack 
Syiabda 

A(l-1); 

PH  Indication(8ymbol)  -  {  PAJI,..U.  SDJJ,K], 
FCJn,n].  DAJ4n  V  12nJ,  SAJ4n  V  12n],  EDJT], 
FS.EJS/R],  FS.AJS/RJ,  FS.CJS/R]  }  A 
(symbd  «  FCJn,n]) 

Action 


PH_Reqiie8t(8ymbol)  «- 
PH_bidication(8ynibol); 
symbol «-  symbol  +  1; 


FS.E.[S4R1  •-  S; 


FS.E,tS/Rl  •-  R; 


83rmbol  symbol  +  1; 


Tx  Idle  •-  set; 


Tx_Idle  set; 


PH_Reqaesl(qrmboI)  •- 
PH_Indicstion(syiidx>l); 
symbol  symbol  +  1; 
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Tiansitioa 

Enabling  Predicate 

Tx  Syn/Asy 
Frame  Symbols 
S(2-2); 

(S4Nif[8ymbol]  V  A-buf[8ymbol])  >= 

{  PA.a,..IJ.  SDJJ,K],  FC,[n.n],  DA,[4n  or  12nl, 

SA.[4n  or  12nl.  INFOJn,..ii_J,  FCSJSn],  ED.[T]. 
FS.E.[R/S].  FS.A.IS/R1.  FS.C,1S/R1  }  A  (symbol  = 
SDJJ]) 

T(29-30): 

End  Syn  or  Asy 
Frame 

S(2-3); 

PH  Request(symbol)  »  {  PA.P,..IJ,  SDJJ.K]. 

FC[in.n].  DA,[4n  or  12n].  SA,[4n  or  12o]. 
INFOJn,..n_J,  FCSJSn],  ED,[T1.  FS.E,[R/S]. 
FS.A,[S/R].  FS.C,[S/R1  }  A 
(symbol  «  FS.C;,[S/R]) 

Anodier  Frame 
S(3.2); 

((S-biif[s]nnbol]  V  A-buf[symbol])  ^  null)  A 
Usable_SbTk 

StarioD  Holding 

SbTkTx 

Completed 

S3-I0: 

STHT  expires  V 

[(Syn_Req_Queued  >  Remaiiiing_Time)  A 
(Asy_Req_Queued  >  Remainmg_Time)]  v 
(~<Syn_Req_Queued  A  -<Asy_Req_Queued) 

Token 

Pl-TO; 

PDU_Tk 

Ring  Opr  and 
Token  Early 
T(0-1); 

T(5-6); 

Ring_Opmational  A  Late_Ct  =  0 

Ring  Opr  and 
Token  Late 
T(0-1); 

T(5-6); 

Ring_Operatianal  A  Late_Ct  >  0 

Ring  not  Opr 
T(0-1); 

T(5^); 

-i(Ring_Opentional) 

Nonrestricted 

T(l-2); 

T(6-7); 

FC,.L  -  0 

Restricted 

T(l-2); 

T(6-7); 

FC,.L  -  1 

Tx_Idle  clear; 
PH_Reque8t[symbol]  •-  (S- 
buf[8yii^l]  V 
A-buf[synibol]); 
symbol  •-  symbol  +  1; 


Tx_Idle  •-  set; 


TRT  •-  T_Opr; 


Late_Ct  •-  0; 


T_Opr  T_Neg; 

TRT  •-  T_^)r, 

Late_a  •-  1; 
Riiig_Opentional  *•  set; 


Token_Class  •* 
nonrestricted 


Token  Class  restricted 
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Tnmsitioa 

Enabling  Predicate 

Action  1 

Usable  Token 
T(2-3); 

Ring_C)perational  A 
{[Syn_Req_Queued  A  Syn_Allowed]  V 
[Lsite  j:t  =  0  A 
(Asy_Req_Queued  A 

Req_Tdcen_Class  =  FC,.L  A 
(Non_priority_Request  V 

TRT  <  T_Pri(Reque8t_Priority)  A 
(Nonrestiicted  Request  A 
(B_Fiag  A  Req_T(^en_Class  =  restricted))]} 

Usable_Tk  true; 

Unusable 

Token 

T(2.3); 

~<Ring_Operational  V 
~'{[Syn_Req_Queued  A  Syn_Allowed]  V 
[Late_Q  =  0  A 
(Asy_Req_Queued  A 

Req_T<dcen_Class  =  FC,.L  A 
(Non_priority_Request  V 

TRT  <  T_Pii(Request_Priority)  A 
(Nonrestiicted  Request  A 
(B_Flag  A  Req_T<ien_Class  =  restricted))]} 

Usable_Tk  •-  false; 

Rqwat  Tdcen 

PH  Indicati(m(symbol)  =  {  PA^,..IJ,  SD,[J,K], 

PH_Request[symbol]  *■ 

Symbols 

FCin,n].  Sl44n  or  12n],  ED4T„TJ  }  A 

PH_Indication(symbol); 

T(3.3); 

~'(Uaable_Tk)  A  (symbol  =  FCJn,n]) 

symbol  •-  symbol  +  1; 

Culture  Token 
T3-I0; 

Usable_Tk 

Tx_Idle  set; 

Token  Repeated 
T3-I0; 

PH_Roquest  =  {  PA.[I,..U1,  SDJJ.K],  FQn.n], 
ED.(T,.TJ.  A 
(symbol  -  ED,[TJ) 

Tx_Idle  •-  set; 

Usable  Token 
Received 

I0-T4; 

Usable_Tk  A  Tk_Received 

THT  4-  disabled; 

Token  Eariy 
T4-E0; 

Late_Q  -  0 

THT  •-  TRT;  I 

TRT  T_Opr,  | 

Token  Late 
T4-L0; 

Late_Q  >  0 

THT  expired; 

Late_Q  •-  0; 

Tx  Syn  Fnune 

S-buf[symbol]  -  {  PA.tI,..IJ,  SDJJ.K],  FCJn,n], 

Tx_Idle  •-  clear; 

syndxds 

DA.[^  or  12n], 

PH  Requestfsymbol] S* 

E((M)); 

SA.[4n  or  12n],  INFOJn,..nJ,  FCSJSn],  ED,[T|, 

buf[symbol]; 

M(W)); 

FS.E,[R/S],  FSAIS/R],  FS.QS/R]  }  A  (symbol  = 
SDJJ]) 

symbol  •-  symbol  +  1; 
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Tfandtioa 


Tx  Token 
Symbols 

E(8^); 

E(12-12); 

U5-5); 

C(5-5); 

T(7.7); 

Token  Issued 
x-IO; 

x=E8,E12,L5. 

C5,T7; 

Tnnsniit 

Tmmndiste 

lO-MO; 

Tx  Tiiwnftdiate 

Symbcds 

M((M)); 

EndTx 

M1-M2; 


Another 

Tmmndietw 

Prune 

M(l-O); 

'Tc  Timnediate 

Coflq>Ietad 

M1-M2; 

No  Token  Oass 
M2-I0; 


Generate  Ack 
KKK); _ 

Tx  SD.FC,DA, 
SA,ED  Syndmia 
0(KK); 


Enabling  Predicate 


Tk-buftsymbol]  =  {  PA,n,..IJ,  SDJJ.Kl, 
FC.[n,n],  EDfTi.TJ  }  A  (symbol  =  PA,[I,])  A 
~»Uad>le_Tk 


PH_Reque8tCsymbol]  »  {  PA,(I,..IJ,  SD,[J,K1. 
FCJn,nl,  ED(T„TJ  }  A  (symbol  »=  ED|TJ) 


requested_aefvice_class  =  Immediate  A 
~|Ring_OperBtiona]  A 
Token_Claas  =  none 

I-buflsymbol]  =  (  PA,[I,..IJ,  SDJJ,K1,  FC.In,n], 

DA,[4n  or  12n],  SA,[4n  or  12n],  lNFO.fn...ii _ 1. 

FCS.[8n].  ED,[T].  FS.E.(R/S1,  FS.A,tS/R],  FS.CJS/R] 
}  A  (symbol  «SDJJ]) _ 

I-buflsymbol]  -  {  PA.[I,..IJ,  SDJJ,K].  FC.In,n], 

DAJte  or  12n],  SA,[4n  or  12n],  lNFO.[n...n _ 1. 

FCSJ8nl,  ED^m.  FS.E,IR/S1,  FS.A.[S/R1,  FS.CJS/R] 
}  A 

(symbol  «  FS.QS/R]) _ 

I-bof[8ymbol]  ft  null 


I-buf[qanbol]  *  null 


Token_CIass  «  none 


Ack_FrunB 


Ack-buflsymbol]  »  {  PA.II,..IJ,  SD,IJ,K].  FQn.n], 
DA,[4n  or  12n],  SA,(4n  or  12n],  ED.[T]  }  A  (qmabol 
-SDJJ]) 


Tniisitioa 


Enabling  Predicate 


Action 


ED  Transmitted 
M(l-2); 


SetE 

G(l-2); 


ResetE 

0(1-2); 


Set  A 
0(2-3); 


SetC 

0(3-4); 


Tx  FS  symbols 
G4-G4; 


Ack  Issued 
G4-I0; 


Recovery 

lO-CO; 


Claim  Entry 
0(0-1); 


PH_Reqiiest(symbol)  =  {  PA^Pi  .U.  SDJJ,K], 
FCi[n,n],  DAi[4n  or  12n],  SA,[4n  or  12n],  ED^tT]  }  A 
(symbol  =  ED,[T1) 


PH_Indicati<ni(symbol)^  Hmt~{  FS.EJS/R]  }  A 
E_Flag 


PH_Indication(symbol)^  ~  {  FS.EJS/R]  }  A 
~'E_Flag 


PH_Indication(8ymbol)^  ^  FS.AJS]  } 
V  A_Flag 


PH_Indication(symbol)^  fi«»  =  {  FS.CJS/R]  }  A 
C_Flag  A  “'N_Flag 


PH_Reqiiest(symbol)  =  {  PA.[I,..IJ,  SDJJ.K], 
FCJn.n],  DA,[4n  or  12n],  SA,[4n  or  12n],  ED,[T| }  A 
(symbol  =  ED,|T]) 


PH_Reque8t(symbol)  =  {  PA^Hi-U.  SDJJ,K1, 
FC,[n,nl,  DAx[4n  or  12n],  SA,[4n  or  12n],  ED^fT], 
FS.E.[R/S].  FS.A.[S].  FS.C,[S]  }  A 
(symbol  »  FS.C.[S/R]) 


FS.E,[S/R]  •-  S; 


FS.E,[S/R]  -  R; 


FS.A,IS/R]  S; 


FS.CJS/R]  *-  S; 


PH_Reque8t 
[symbol]  •- 

{  FS.E,[R/S],  TS.AJLS], 
FS.C.[S]  } 


Tx_Idle  •-  set; 


SM_MA_CONTROL.request[Cl8im] 


Tx  Claim  Claim-buf[8ymbol]  -  {  PA.P,..IJ,  SD.[J,K],  FC.[n,n], 

Frame  Sjrmbols  DA|[4a  or  12n],  SA.[4n  or  1^],  INFOJn,..n^, 
C(2-2);  FCSJSn],  EDJTI.  FS.E*[R/S],  FS.A.[S/R],  FS.CJS/R] 

}  A  (symbol  -  SDJJ]) 


T_Opr  •-  T_Max; 
TOT  •-  T_^>r, 
T(dcen_Clas  =  none; 


Tx_Tdle  •-  clear; 
PH_Request{8ymbol]  *- 
Claim-lNif[symbol]; 
qrmbol  •-  symbol  +  1; 


Successful 

Claim 

C(2-3); 


Failed 

C2-B0; 


PH_Reque8t[83rmbol]  «  Claim-baf[8ymbol]  A  TOT 
expires 


Unusd>le  Tcricen  Tk_Received  A  ~<Usable_Tk 

Received 

I0-T5; 


TOT  •-  T_Opr; 
Token_Clas8  *- 
nonrestricted; 


Beacon_type  •- 
Unsuccessful  Claim; 
Beacon.DA  null; 


THT  disabled; 
Tx_Idlc  clear, 
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Tnnsitiaii 

Enabling  Predicate 

Actim 

Beacoo 

Requested 

lO-BO; 

SM_MA.CONTROL.teque8t[Beacon] 

Tx_Idle  •-  clear; 

Tx  Beacoo 

Ffame  Symbols 
B((M)); 

Beacon-buf[symbol]  *=  {  PAJI,..IJ.  SDJJ.K], 

FC,[n,n],  DA,[4n  or  12n],  SA,[4n  or  12n], 
INFOJn,..n_J.  FCSJSnl,  ED.m.  FS.E.[R/S1. 
FS.A,tS/Rl,  FS.C.[S/R]  }  A  (symbol  =  SDJJ]) 

Tx_ldle  •-  clear; 
PH_Reque8t[symbol]  «- 
Beacoo-buf[symbol]; 
symbol  *-  symbol  +  1; 

Fixed 

BO-IO; 


PH_Iiidicatioii(8ymbol)  *-  {  Beaon  symbols  }  A 
My_Beacoo 


Tx_Idle  set; 


6.  Local  and  Timer  Data  Type  Specification 


Table  3  presents  the  local  and  timer  data  type  specification.  This  table 
contains  each  data  type  used  in  the  machines  transition  tables.  Its  range,  initial  value,  and 
purpose  are  included.  Values  on/off,  true/false,  set/reset  of  boolean  variables  have  the 
same  meaning  and  can  be  used  interchangeably.  Data  types  marked  with  (*)  are  not 
specified  in  the  FDDI  MAC  standard. 


TABLE  5:  LOCAL  AND  TIMER  DATA  TYPE  SPECIFICATION 


Name 

Range 

Initial 

value 

Purpose  1 

Erfor_Ct 

[0.  00) 

0 

Error  Q>unter  -  | 

Count  of  reportable  frame  errors. 

FfBIDB_Q 

[0.  00) 

0 

Frame  Counter  - 

Count  of  all  frames  received. 

Late_Ct 

[0,  00) 

0 

Late  Counter  - 

Count  of  TRT  expirations  (Token  Lateness). 

Lo8l_Ct 

[0.  00) 

0 

Lost  Counter  • 

Count  of  PDU  d^ected  as  lost. 

8ymbol_ct  (*) 

[0,  00) 

0 

Lost  Counter  • 

Count  of  symbols  in  a  transfer  of  data. 

Ack_ct  (*) 

[0.  00) 

0 

Acknowledgment  Counter  • 

Count  of  acks  received. 

A_FIag 

boolean 
[aet,  reset] 

reset 

Address  recognized  indicator  Flag  • 

Indicates  Destinations  Address  (DA) 
match  in  last  recmved  frame. 

C_FIag 

boolean 
[set,  reset] 

reset 

Frame  cr^ied  indicator  Flag  - 

Indicates  successful  copying  of  last  received 

frame. 

E_Flag 

boolean 
[set,  reset] 

reset 

Error  detected  indicator  Flag  • 

Indicates  error  detected  in  last  received  frame. 

H_Flag 

boolean 
[set,  reset] 

reset 

Higher  address  Flag  - 

Indicates  Higher  Source  Address  (HSA) 

received. 

L_Fla* 

boolesn 
[set,  reset] 

reset 

Lower  Address  Flag  • 

Indicates  Lower  Source  Address  (LSA) 
received. 

M_Flag 

boolean 
[set,  reset] 

reset 

My  address  Flag  - 

Indicates  My  Source  Address  (MSA)  received. 
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Name 

Range 

N_Flag 

boolean 
[set.  reset] 

R_Flag 

boolean 
[set,  reset] 

Rc_Start 

boolean 
[true,  folse] 

T_Req 

integer  number  of 
symbol  times  at  100 
Mbits/sec 
[T_Min,  T_Max] 

T_Bid_Rc 

integer  number  of 
symbol  times  at  100 
Mbits/sec 
[T_Mm,  T_Max] 

T_Max 

integer  number  of 
symbol  times  at  100 
Mbits/sec 
[0,  00) 

T_Mm 

integer  number  of 
symbol  times  at  100 
Mbits/sec 
[0.  00) 

T_Neg 

integer  number  of 
symbol  times  at  100 
Mbits/sec 
(T_Mui,  T_Max] 

T_Opr 

integm’  number  of 
symbol  times  at  100 
Mbits/sec 
[T_Min,  T_Max] 

T_Pri(Request_p) 

integer 
[0,  00) 

Token_Class 

3  values 

THT 

integer  number  of 
synfool  times  at  100 
Mbits/sec 
[T_Mm,  T_Max] 

Initial 

▼alue 


Purpose 


Next  address  Flag  - 

Indicates  Next  Station  (NSA)  Addressing. 


Restricted  class  Flag  - 

Indicates  restricted  T(dcen_class  for  the  last 

valid  T(^en_received. 


Received  start  signal  - 

Indicates  the  starting  of  an  incoming  PDU. 


Requested  TTRT  - 

Indicates  the  Requested  TTRT  for  this  MAC’S 
synchronous  traffic  to  negotiate  for  the  lowest 
value  of  T_Opr. 


Bidding  TTRT  Recrived  - 

Indicates  the  Bidding  TTRT  received  by  this 

station  in  Claim  Frames. 


Maximum  TTRT  - 

Indicates  the  Maximum  TTRT  to  be  supported 
by  this  station. 


Minimum  TTRT  • 

Indicates  the  Minimum  TTRT  to  be  siqiported 
by  this  staticm. 


T_Opr  =  Negotiated  TTRT  - 
lowest  value  Indicates  the  Negotiated  TTRT  during  Claim 
of  T_Req  process  (ha  receiver). 

The  lowest  value  of  T_Req  becomes  T_Opr 
for  the  ring. 


Operative  Value  of  TTRT  - 

Indicates  the  Operative  value  of  TTRT  for  this 

station  (in  transmitter). 


T  Max 


Priority  Request  Values  - 

Set  of  Request  priority  Tcdcen  rotation  time 

thresholds. 


Class  of  token 

Restricted,  nonrestricted,  and  none 


current  value  Tdcen^Holding  Timer  - 

ofTRT  Controls  the  time  of  a  MAC  Asynchronous 
frame  transmission. 
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Name 

TRT 

TTRT 

tv5c 

STHT(*) 

Idle(*) 

Txjdle(*) 

FO_Error 

FR_Strip 

PDU_Fraiiie(^ 


Range 


Initial 

value 


Purpose 


integer  number  of 
symbol  times  at  100 
Mbits/sec 
[T_min,  T_Max] 


integer  number  of 
symbol  times  at  100 
Mbits/sec 
[0.  00) 


integer  number  of 
symbol  times  at  100 
Mbits/sec 
[0,  oo) 


integer  number  of 
symbol  times  at  100 
Mbits/sec 
[0,  oo) 


boolean 
[true,  fidse] 


boolean 
[true,  fidse] 


boolean 
[true,  fidse] 


boolean 
[true,  Adse] 


boolean 
[true,  ftlse] 


current  value  Tokoi-Rotation  Timer  • 
of  T_Opr  Controls  ting  scheduling  during  normal 

operation  and  is  used  to  detect  and  recover 
from  serious  ring  error  situations. 


Target-Token  Rotation  Time  - 
Indicates  the  various  times  that  can  be 
assumed  during  different  MAC  processes 
(T_Req,  T  Bid  Rc,  T  Max,  T_Min,  T  Neg, 
T.Opr). 


Valid-Transmission  Timer  - 

To  recover  from  transient  ting  error  situations. 


Subtoken  Holding  Timm'  - 
Controls  the  time  of  the  subtoken  data 
transmission  to  ensure  controlled  concurrent 
access. 


Idle  signal  - 

The  Receiver  generates  this  signal  whenever 
the  incoming  symbol  is  an  idle  s3nnbol. 


Tx  Idle  variable  - 

The  Transmitter  sets  this  local  variable 
wdienever  it  is  requested  to  enter  the  TX  IDLE 
state.  This  occurs  due  to  an  Idle,  or  Fr_Sttip, 
or  FO_error  signal  firom  the  receiver  or  after 
completion  of  a  PDU  transmission. 


Format  Error  signal  - 

The  Receiver  generates  this  signal  whenevn 
an  incoming  symbol  does  not  conform  with  a 
sequence  specified  in  the  FDDI  MAC 
standard. 


Frame  Strip  signal  - 

The  Recmver  geimates  this  signal  udienever 
an  incoming  symbol  sequence  indicates  a 
condition  for  mnoving  a  PDU  from  the  ring. 


Frame  signal  - 

The  Receiver  generates  diis  signal  udien  it 
scans  the  FC  field  of  the  incoming  PDU  and 
recognizes  that  this  PDU  has  a  format  of 
Frame. 
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Name 

Range 

Iiutial 

value 

Purpose 

PDU_Ack(*) 

boolean 
[tnie,  fidse] 

fidse 

Ack  signal  - 

The  Receiver  generates  this  signal  \dien  it 
scans  the  FC  field  of  the  incoming  PDU  and 
recognizes  that  this  PDU  has  a  format  of 
Acknowledgment. 

PDU_ll(*) 

boolean 
[tnie,  false] 

fidse 

Token  signal  - 

The  Receiver  generates  this  signal  when  it 
scans  the  FC  field  of  the  incoming  PDU  and 
recognizes  that  this  PDU  has  a  format  of 

Token. 

PDU_Sb»k(*) 

boolean 
[tnie,  fidse] 

false 

Subtoken  signal  - 

The  Receiver  generates  this  signal  vdien  it 
scans  the  FC  field  of  the  incoming  PDU  and 
recognizes  that  this  PDU  has  a  format  of 
Subtcdcen. 

Copy_Fmne(*) 

boolean 
[tnie,  fidse] 

fidse 

Copy  Frame  variable  • 

The  Receiver  set  this  variable  udien  a  frame  is 
to  be  copied  for  the  local  entity  (e.g.,  an  LLC 
or  frame  addressed  to  this  station). 

FR_Received 

boolean 
[tnie,  fidse] 

fidse 

Frame  Received  signal  - 

The  Receiver  generates  this  signal  when  a 

PDU  of  Frame  format  is  received. 

Ack_Fniiie(*) 

boolean 
[tnie,  fidae] 

fidse 

Ack  Frame  signal  • 

The  Receiver  generates  diis  signal  for  die 
transmitter  on  the  opposite  ring  when  a  PDU 
of  Frame  format  was  received  and  copied 
locally  into  the  receive  buffer. 

Copy_Ack(*) 

iKxdean 
[tnie,  ftlae] 

fidse 

Copy  acknowlegment  • 

The  Recmver  set  this  variable  when  an 
acknovdedgment  is  to  be  copied  to  save  die 
frame  status  rqpoit  for  the  local  entity. 

My_Claim 

boolean 
[tnie,  fdae] 

fidse 

My  Claim  signal  • 

The  Receiver  generates  diis  signal  to  indicate 
an  incoming  claim  frame  with  this  MAC'S 
own  bid. 

Higlier_Ckum 

boolean 
[tnie,  fidae] 

fidse 

Higher  Claim  signal  - 

The  Receiver  generates  this  signal  to  indicate 
an  incoming  claim  frame  with  a  MAC  higher 
bid. 
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Name 

Range 

Initial 

value 

Purpose  1 

Low«’_Claim 

boolean 
[true,  false] 

false 

Lower  Claim  signal  •  I 

The  Receiver  generates  this  signal  to  indicate  | 
an  incoming  claim  frame  with  a  MAC  lower  I 
bid.  1 

My_Beacoa 

boolean 
[true,  fidse] 

false 

My  Beacrm  sigiud  -  H 

The  Receiver  gmerates  this  signal  to  indicate  | 
an  incoming  MAC’S  own  beacon  frame. 

Otlier_Beac<» 

boolean 
[true,  fidse] 

false 

Other  Beacon  signal  - 

The  Receiver  gmerates  this  signal  to  indicate 
an  incoming  beaccm  frame  from  other  MAC. 

Other  LLC  or  SMT 
(*) 

boolean 
[true,  false] 

false 

Other  LLC  or  SMT  frame  signal  - 
The  Receiver  generates  this  signal  to  indicate 
that  an  incoming  frame  is  an  LLC  or  SMT 
frame  addressed  to  other  station. 

Sbtk_Flag(*) 

boolean 
[set,  reset] 

set 

Subtoken  Flag  - 

Indicates  if  an  incoming  subtcdcen  is  usable  or 
not. 

Sbtk_Received(*) 

boolean 
[true,  fidse] 

false 

Subtoken  Received  signal  • 

The  Receiver  generates  this  signal  to  indicate 
that  a  subtoken  has  been  received. 

U8aUe_tk(*) 

boolean 
[tnie,  fidse] 

fidse 

Usable  Token  - 

The  Transmitter  uses  this  variable  to  check  if 
the  Udcen  can  be  ciqMured. 

Uaable_Sbtk(«) 

boolean 
[true,  fiilse] 

fidse 

Usable  Subtcdren  • 

The  Transmitter  uses  this  variable  to  dieck  if 
the  subUdreo  can  be  captured. 

Tk_Received 

boolean 
[true,  fidse] 

fidse 

Token  Received  signal  • 

The  Receiver  generates  this  signal  to  indicate 
that  a  tdcen  has  been  received. 

Ring_Opentioaal 

boolean 
[tnie,  fidse] 

true 

Ring  Operational  - 

Indicates  the  opmadonal  status  of  the  ring. 

Wiap(*) 

boolean 
[true,  fidse] 

true 

Wrap  configuration  variable 

Indicates  that  a  serious  jdiysical  fidlure  has 
occurred  and  die  configuraticm  changed  to  me 
logical  ring.  This  is  an  overall  network- 
controlling  function. 

WaiW) 

boolean 
[true,  fidse] 

true 

Wait  primary  ring  transmission- 
During  simultaneous  transmission  indicates 
that  primary  ring  is  transmitting. 

Wait«^*) 

boolean 
[true,  false] 

true 

Wait  secmdary  ring  transmission- 
During  simultaneous  transmission  indicates 
that  secondary  ring  is  transmitting. 
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Name 


Range 


biitial 

▼alue 


Purpose 


Syn_Req_Queued 

boolean 
[tnie,  false] 

fidse 

Synchronous  Request  Queued  - 
Indicates  a  request  for  transmission  of 
synchronous  PDU  queued. 

Syn_band_allocation 

boolean 
[tnie,  ftlse] 

Cdse 

Synchronous  Bandwidth  Allocation  - 
^icates  the  alloted  bandwidth  for  die  stadcms 
during  the  synchronous  smvice. 

A^_Req_Queued 

boolean 
[true,  Cilse] 

fidse 

Synchronous  Request  Qumied  - 
Indicates  a  request  for  transmission  of 
asynchronous  PDU  queued. 

Reiiigiiiing_Time(*) 

integer  numb«‘  of 
symbol  times  at  100 
Mbits/sec 
(0,  max) 

0 

Remaining  time  of  subtoken  duradoo- 
Indicates  the  amount  of  time  available  after 
transmissitm  of  frames. 

Re<LQ0«»*thX*) 

integer  number  of 
symbol  times  at  100 
Mbits/aec 
(0,  08) 

0 

Requested  Queued  Lengdi  - 

Indicates  the  length  in  number  of  symbol  time« 

(duration)  of  the  requested  PDU  queued  fiir 

transmission. 

Sbtk_Claas(*) 

integer  number  of 
syndMl  times  at  100 
Mbits/sec 

10,  08) 

0 

Subtidcen  Class  - 

Indicates  the  length  in  number  of  symbol  dmeg 
(duration)  of  the  Subtoken.  Class  is  a  stqnvise 
function  of  the  length. 

PH.Invalid 

boolean 
[true,  fidse] 

fidse 

PH_Invalid  is  the  signal  parameter  of  the  PHY 
to  MAC  Invalid  Indication  primitive  •  When 
this  occurs  the  PHY  entity  is  unable  to  present 
a  valid  symbol  to  MAC  and  die  Recmver 
enters  into  its  LISTEN  state. 

SM  MA 

CONTROL. 

fequest(beacoo) 

boolean 
(true,  fidae] 

fidse 

SMT  to  MAC  Control  Request  primidve  widi 
Beacon  signal 

parameter  -  When  this  occurs  die  Transmitter 
enters  into  its  TRANSMIT  BEACON  state. 

SM  MA 

CONTROL. 

feqoest(nset) 

boolean 
[true,  fidae] 

fidse 

SMT  to  MAC  Control  Request  primitive  widi 
Reset  signal  parametm  -  When  this  occurs 

MAC  generates  the  MAC_Re8et  signal. 

Mac_Reiet 

boolean 
[true,  fidae] 

blse 

MAC  Reset  signal  - 

MAC  generates  this  signal  in  leqwnse  to  a 
contiol_action  requested  by  SMT  to  reset  the 
MAC  state  machines  (Receiver  and 

Transmitter).  When  it  occurs  die  Receivo' 
enters  into  its  LISTEN  state  andte 
transmitter  enters  into  its  IMJB  Me. 
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Name 

Range 

PH_Request 

(qrmbol) 

array  [l..max]  of 
buffer 

PH_Indication 

(syndxil) 

array  [l..max]  of 
buffer 

S-buf(symbolX*) 

array  [L.max]  of 
buffer 

A-buf(8]nnbolX*) 

array  [L.iiiax]  of 
buffer 

'xv-buRsymbolX*) 

array  [l..max]  of 
buffer 

Symbcd 

(0..MFL1 

PAn,..IJ 

field  of  [1,..U  I<U« 
tymbols 

SD(J,K] 

field  of  J  and  K 
qrmbola 

DA{4n  V  12a] 

field  of  4n  OT  12n 
qrmbola 

SA(4n  V  12n] 

fidd  of  4n  OT  12n 
symbola 

Initial 

value 


Purpose 


PH_Reque8t  Buffo'  -  It  is  the  ou^t  buffer  at 
the  Transmitter  side.  It  holds  each  outgoing 
symbol  on  a  transfer  of  data  from  the  MAC 
entity  to  the  PHY  entity.  This  transfer  of  data 
occurs  udieaever  a  PH_Request  signal  is  sent 
to  PHY  udwnever  MAC  has  a  symbol  to 
output. 


PH_Indication  Buffer  - 

ii^Mit  buffer  at  the  Receiver  side.  It  holds  each 
incoming  symbol  cm  a  transfer  of  data  from 
the  PHY  entity  to  MAC  entity.  This  transfer 
of  data  occurs  wdienever  a  PH_Indication 
signal  comes  from  PHY  after  a  symbol  is 
decoded. 


Synchonous  Buffer  - 

buffer  for  transmissitm  of  synchitmous  queued 
SDUs. 


Asynchonous  Buffer  • 

buffer  for  transmissirm  of  asynchronous 

qumed  SDUs. 


Receive  Buffer  -  It  is  the  buffer  for  ccq)ying 
frames  to  the  local  entities. 


Symbol  is  a  pointer  to  the  current  symbol  on 
the  buffer  array.  Symbols  are:  J,  K,  T,  R,  S, 
I,  or  n  and  they  rqnesent  the  smallest 
signalling  dement  used  by  the  DDL  entities. 
For  both  Receiver  and  Transmittn’  machines 
symbol  is  a  generical  rqnesentation  to  denote 
a  pointa'  to  the  current  qrmbol. 


Preamble  of  a  PDU  format  - 
Contains  a  variable  number  of  Idle  symbols. 
The  subscripts ,  and ,  stand  for  recdved  and 
transmitted  respectivdy. 


Starting  Ddimiter  of  a  PDU  format  - 
Contains  die  symbol  J  followed  by  K. 


Destination  Address  of  a  frame  format 
Contains  a  fixed  number  of  dther  four  or 
twdve  data  quartet  symbols. 


Source  Address  of  a  frame  format  • 
Contains  a  fixed  number  of  either  four  or 
twdve  data  quartet  (n)  symbols. 
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Name 


Range 


Initial 

▼altie 


Purpose 


FC(n,n] 

INFO{n,..iiJ 

FCS[8n] 

ED[1T  V  2T1 
FS.E[S/R], 

FS.A(S/R1,  FS.QS/Rl 
SL[^  V  12a] 

EL(4a  V  12a] 

CLASS[2n](*) 

Valid  Data  Lagdi 

Valid  FCS, 

MSA 

MLA 


field  of  2n  symbols 


fidd  of  fn|..n^||l  of 
symbols 


field  of  8n  symbols 


field  of  IT  or  2T 
symbols 


field  of  2  3  S/R 
symbols 


field  of  4a  or  12n 
symbols 


field  of  4a  or  12a 
symbols 


field  of  2n  symbols 


boolean 
[true,  fUse] 


boolean 
(true,  ftJse] 


16-bit  addresses 


48-bit  addresses 


Frame  Qmtrol  field  of  a  PDU  format  - 
Qmtaias  two  data  quartet  (n)  symbols  udiose 
meaning  are:  the  fi^  data  quartet  n  =  CLFF 
bits  and  the  second  data  quartet  n  =  ZZZZ 
bits. 


Information  field  of  a  frame  format  - 
Contains  a  variable  numb«  of  data  quartet  (n) 
symbols. 


Frame  Check  Sequence  of  a  fiame  format  - 
Contains  dght  data  quartet  (n)  symbols. 


Ending  Delimiter  field  of  a  PDU  format  - 
Contains  oot  or  two  Terminate  (T)  symbols. 


Frame  Status  field  of  a  frame  format  - 
Contains  three  or  more  control  indicator 
symbols  Set  (S)  or  Reset  (R). 


Start  Limit  field  of  a  subtoken  format  - 
Indicates  the  address  of  the  station  v^ere  the 
subtoken  starts  to  be  valid  for  use.  Contains  a 
fixed  number  of  either  four  or  twelve  data 
quartet  symbols. 


Ending  Limit  field  of  a  subtoken  format  - 
Indicates  the  address  of  the  station  vrfiere  the 
subtcdcen  stops  to  be  valid  for  use.  Contains  a 
fixed  number  of  either  fiiur  or  twelve  data 
quartet  symbols. 


Class  field  of  a  subbdcen  format  - 
Indicates  the  duration  of  dm  frame  allowed  to 
be  transmitted  by  die  station  using  this 
subldten.  Contains  a  fixed  nuniber  of  two  data 
quartet  symbols  (n). 


Valid  Data  Leogdi- 

(a)  Is  an  integral  number  of  Dati  syndmls 
pairs  between  SD  and  ED; 

(b)  Satisfies  the  taUe  of  interpretation  of  FC 
field  in  the  MAC  FDDI  standard. 


Valid  Frame  Check  Sequence- 
Sadsfies  the  criteria  of  FCS  checking 


My  Short  Address 


My  Long  Address 
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V.  PROTOCOL  VERmCATION 


A.  VERIFICATION 

The  basic  goal  of  a  fonnal  model  for  a  protocol  specification  is  to  eliminate  the 
ambiguities  and  difficulties  associated  with  completeness  and  correctness.  To  avoid 
design  OTors  before  any  implementation,  logical  reasoning  can  be  applied  to  demonstrate 
that  the  protocol  meets  its  specification.  All  possible  interactions  on  the  specified  layer 
service  are  checked  to  ensure  that  the  protocol  satisfies  the  layer’s  specification.  This  is 
the  primary  goal  of  protocol  verification. 

Conceptually,  protocol  verification  checks  for  general,  specific,  safety,  and  liveness 
properties.  General  properties  are  implicit  parts  of  all  service  specification  (e.g., 
deadlock,  starvation,  completeness,  and  termination).  Specific  properties  require  the 
provision  of  the  particular  service  specification  (e.g.,  the  synchronous  service  bandwidth 
allotment  in  FDDI).  Safety  is  the  conformance  verification  of  the  protocol.  It  compares 
actual  protocol  acticms  with  its  service  specification  (e.g.,  if  a  station  captures  a  toten, 
it  will  first  deliver  its  synchrcmous  traffic  and  then  its  asynchronous  traffic  according  to 
the  timed-token  rules).  Liveness  is  a  property  that  oisures  the  completion  of  specified 
smvices  in  a  finite  time.  For  analysis  of  protocol  efficiency  and  responsiveness  numerical 
bcMinds  are  considered. 

Protocol  correctness  by  the  establishmoit  of  proofs  is  one  effective  aj^roach  used 
in  protocol  verification.  Proofs  are  particularly  useful  for  showing  whether  a  protocol  is 
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modeled  correctly.  This  verification  technique  identifies  errors  and  can  determine  the 
cause. 

B.  PROTOCOL  CORRECTNESS  THROUGH  PROOFS 

A  major  strength  of  the  formal  specification  presented  in  this  thesis  is  that  it  allows 
for  proof  of  protocol  correctness  by  the  application  of  elementary  logic  to  statements. 
Givoi  a  problem  statement,  chain-reaction  arguments  can  be  established  by  navigating 
through  the  state  diagram  and  transition  table.  Statemrats  are  matched  with  oiabling 
predicates.  Each  oiabling  predicate  has  the  property  that  it  must  be  either  true  or  false. 
The  statements  are  connected  in  a  chain-reaction  or  combined  to  form  new  statements. 
As  a  result,  truth  tables  can  be  constructed  to  prove  that  a  statement  will  be  mther  true 
or  false  on  the  protocol  specification.  Proofs  can  be  established  to  verify  the  correctness 
of  all  protocol  modules  and  chain-reaction  arguments  which  consider  each  module 
precondition  and  postcondition  can  be  aq)plied  to  prove  the  complete  protocol.  The  next 
subsection  provides  an  example  of  proof  for  correctness,  given  a  specific  protocol 
module. 

To  formalize  the  proof  the  foUowing  commonly  used  notational  conventions  are 
assumed: 

A  :  and; 

V  :  or, 

:  not; 

^ :  implies. 
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The  chain-reaction  type  of  argument  is  used,  which  is  symbolized  by  the  tautology 
[(p  q)  A  (q  =*  r)]  =*  (p  =*  r). 

1.  Proof  that  an  LLC  Frame  is  Copied  and  an  Acknowledgment  is  Sent 

Given  the  following  statements  prove  that  an  arriving  LLC  flrame  will  be 
copied  by  the  Destination  Address  (DA)  station  and  an  acknowledgment  returned  to  its 
originator.  Given  the  following  statements: 

•  (a)  The  arriving  frame  has  the  contents  of  its  DA  field  equals  to  one  address  of  the 
set  of  this  Station  Short  Addresses  (SSA); 

•  (b)  The  Frame  Status  field  (FS)  has  its  Control  Indicator  “A"  received  as  reset  (R); 
and, 

•  (c)  The  frame  is  valid; 

prove  that  in  accepting  the  statements  the  MAC  Receiver  will  copy  the  frame  locally  and 
return  an  acknowledgment. 

To  prove  that  the  MAC  Receiver  will  copy  the  frame  and  an  acknowledgment 
will  be  sent  it  must  be  shown  that  (1)  the  Receiver  will  set  the  copy  flag  (C_Flag),  (2) 
the  Receiver  will  sent  the  frame  acknowledgment  signal  (SIGNAL  Ack_Frame)  to  the 
transmitter  cm  the  opposite  ring  which  (3)  will  transmit  an  acknowledgment. 

In  the  protocol  formal  specification  the  statements  (a),  (b),  and  (c)  are 
equivalent  to  [(FC.L,  =  0)  A  (DA,  €  {SSA})],  FS.A,  =  R,  and  Valid_Frame 
req)ectively.  All  the  statements  are  assumed  to  be  true,  unless  otherwise,  specified. 
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Let  the  statements  be  denoted  as  follows: 


p:  [(FC.L,  =  0)  A  (DA,  €  {SSA})], 
q:  FS.A,  =  R, 
r  Valid_Frame. 

Also,  denote  the  following  statements 

a:  A_Flag, 
s:  Copy_Frame, 
c:  C_Flag,  and 
k:  SIGNAL  Ack_Frame 
t.  Txjldle  clear; 

PirRequest[symbol]  Ack-buf[symbol]; 
symbol  ♦-  symbol  +  1; 

u:  PH  Request(symbol)  =  {  PAj,[I,..IJ,  SD,[J,K],  FCJn,n],  DA,[4n  or 
12n],  SA.[4n  or  12nl,  ED,IT1,  FS.EJR/S],  FS.AJS],  FS.CJS]  }  A  (symbol  = 
FS.CJS/R]) 

v:  Tx_Idle  set; 


Part  CD:  To  show  that  if  p  and  r,  then  c. 

The  MAC  Recdver  State  Diagram  (Diag.  2)  and  transition  table  show  that 
the  statement  p  is  an  enabling  predicate  for  the  transition  F(0'1)  "DA  Match*.  The 
corresponding  action  implied  by  this  transition  is  the  statement  a.  Therefore, 

p^a. 

The  transition  F(l-2)  "Copy  Frame  to  Local  entity  (LLC,  SMT,  MAC) 

shows  that 

a^s. 

Given  the  statement  r  and  the  resultant  logic  s  the  transition  F(7-8)  "Frame 
Cqned*  showed  in  Diag.  2a,  it  follows  tiiat  the  statement  c  holds  in 

(r  A  s)  ^  c. 
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Part  (2):  To  show  that  if  q  and  c,  then  k. 

Given  q  and  the  resultant  logic  of  c,  they  will  form  the  enabling  predicate  for 
a  transition  F(7-8)  "Ack  Frame"  in  Diag.  2a.  of  the  MAC  Receiver.  It  follows  that  k 
holds  as  a  corresponding  action  of  this  transition,  therefore 

(q  A  c)=*  k. 

This  part  of  the  proof  showed  that  the  Copy_Flag  will  be  set  and  the 
SIGNAL  Ack_Frame  will  be  sent  to  the  transmitter  on  the  opposite  ring. 

Part  (Sal:  To  show  that  if  k  then  t. 

The  Mac  Transmitter  State  Diagram  (Diag.  9)  and  Transmitter  Transition 
Table  show  that  the  statement  k  is  an  dial  ling  predicate  for  the  transition  lO-GO 
"Generate  Ack."  The  Transmitter  at  this  point  will  have  the  symbol  pointer  pointing  to 
the  symbol  J  of  the  SD  field  in  the  buffer  array  Ack-buf  of  symbols.  The  transition  GCO* 
0)  Tx  SD,FC,DA,SA,ED  Symbols  will  incrementally  occur  for  every  symbol  implying 
the  corresponding  action  t.  Symbols  from  the  Acknowledgment  buffer  are  placed  into  the 
PH_indication  buffer  for  transmission  over  the  physical  medium.  Therefore, 

Part  (3bl:  To  show  that  if  t  thoi  u,  and  if  u  then  v. 

The  transition  G4-I0  "Ack  Issued"  shows  that  whoi  the  symbol  being 
transmitted  out  of  PH_indication(symbol)  buffer  reaches  the  control  indicator  C  of  the 
FS  field  that  the  Transmitter  has  issued  the  acknowledgment  and  entered  the  TX  IDLE 
state  10.  For  simplification,  it  is  assumed  that  the  pointer  symbol  is  incremented  and  will 
reach  the  control  indicator  C.  Note  that,  if  no  assumption  is  made,  this  st^  can  also  be 
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proved  by  induction  on  the  array  of  symbols.  Also,  the  proof  could  be  further  extended 
to  show  that  the  acknowledgment  is  sent  with  the  control  indicators  E  reset,  A  set,  and 
C  set  in  the  frame  status  field  FS.  Therefore, 

t=>  u 


and  finally. 


n  V. 

This  part  of  the  proof  showed  that  the  Transmitter  on  the  opposite  ring  has 
sent  an  acknowledgment  to  the  frame  originator  which  completes  the  proof. 


i 
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VI.  CONCLUSIONS 


A.  REVIEW  OF  THE  RESEARCH 

The  goal  of  the  research  documoited  in  this  Thesis  was  to  develop  the  details  at 
'*  the  MAC  level  of  an  improved  FDDI  protocol  and  to  provide  its  formal  specification. 

*  Essoitially,  the  protocol  improvement  is  achieved  by  increasing  the  ring  utilization.  The 

Thesis  investigated  the  FDDI  MAC  and  developed  the  details  of  the  access  control 
mechanism  of  a  protocol  that  can  raise  the  total  network  throughput  to  a  maximum  of 
300  Megabits  per  second  while  maintaining  the  same  data  transfer  of  100  Megabits  per 
second  of  the  original  FDDI.  The  method  developed  to  increase  throughput  was  based 
upon  simultaneous  transmissions  on  the  dual  ring  with  concurrent  ring  access.  A  single 
MAC  which  controls  access  to  both  rings  was  proposed.  This  MAC  structure  adds  a 
degree  of  complexity  to  the  existing  token  ring  FDDI  network;  however,  with  the  currmt 
improvemoits  in  fiber  optics  technology  it  is  feasible  to  design  and  implement  such 
interface. 

^  This  research  presented  this  method  of  access  to  ensure  the  improvement  in 

throughput.  In  fact,  this  method  called  Timed-Token  Controlled  Concurrent  Access  is  an 
enhancement  to  the  Timed-Token  Access  method  of  FDDI  which  remains  unchanged  in 
the  improved  protocol.  This  method  allows  concurrent  access  to  differrat  partitions  of 
the  same  physical  medium;  thus,  increasing  ring  utilization.  The  method  introduced 
additional  PDU  formats  necessary  to  carry  out  the  concurrent  access  to  the  ring.  In 
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addititm,  changes  in  the  FDDI  stripping  mechanism  for  protocol  normal  operation  were 
necessary.  Also,  Algorithms  to  generate  subtoken  duration  were  presented  and  analyzed. 

The  improved  protocol  was  designed  to  meet  the  requirements  for  a  top  level 
backbone  network  while  maintaining  key  characteristics  of  FDDI.  This  backbone  network 
can  be  used  primarily  to  link  lower  speed  Local  Area  Networks  (LAN),  including  other 
FDDI  LAN.  The  key  characteristic  of  reliability  offered  by  FDDI  through  its  ring 
reconfiguration  function  is  maintained  in  the  improved  protocol.  When  a  failure  occurs 
the  same  recovery  procedures  of  FDDI  will  reconfigure  the  improved  FDDI  network. 
When  in  this  condition,  the  network  loses  the  improvement  in  throughput;  however,  it 
maintains  the  same  functionality  of  FDDI,  '  'hich  allows  communication  to  continue. 
Another  key  characteristic  embedded  in  the  timed-toten  protocol  is  the  initialization 
process.  This  process  remains  unchanged  in  the  improved  protocol. 

The  major  achievement  of  this  thesis  was  the  conversion  of  the  improved  FDDI 
protocol  into  a  formal  model  of  specification.  The  flexibility  and  suitability  of  the  model 
"Systems  of  Communicating  Machines”  allowed  the  formulation  of  a  detailed  and  precise 
protocol  specification. 

This  specification  is  useful  in  sevoal  ways.  First,  it  enhances  the  protocol 
understanding  and  intopretation.  Second,  it  contributes  to  reduce  protocol  ambiguities 
which  is  a  good  feature  for  interoperability  achievemoit.  Third,  it  allows  control  of  each 
protocol  module  or  state  behavior  which  is  a  desirable  feature  in  verification  and  error 
checking.  Fiiudly,  the  specification  can  be  used  to  proof  the  protocol  correctness;  thus, 
it  provides  means  to  conduct  a  protocol  exact  analysis. 
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B.  ISSUES  FOR  FURTHER  RESEARCH 


This  thesis  envisioned  a  Local  Area  Network  protocol  that  enhances  the  current 
FDDI.  FDDI  is  already  an  enhancement  of  802.5  token  ring  designed  to  take  advantage 
of  fiber  optics  using  a  timed  mechanism  that  achieves  simplicity  and  fairness.  However, 
all  the  possibilities  were  not  explored.  FDDI  can  be  improved.  The  resources  of  an 
FDDI  network  are  waiting  to  be  efficiently  used.  The  improved  FDDI  protocol 
researched  in  this  Thesis  is  a  logical  superset  of  FDDI  with  an  added  degree  of 
complexity.  Because  of  this  complexity,  only  the  first  steps  were  achieved.  Therefore, 
much  work  still  can  be  done.  This  research  opens  the  following  areas  for  further  studies. 

•  A  simulation  which  model  the  improved  MAC  protocol. 

•  A  comprehensive  performance  analysis. 

•  The  fairness  of  access  to  transmit  on  the  unused  segment  and  its  dependence  on  the 
Timed>Token  mechanism. 

•  Interface  implemoitation  feasibility  of  the  Single-MAC*Dual-PHY  structure  for 
simultaneous  transmission  on  the  dual  ring  with  the  controlled  concurrait  access 

•  Proof  that  the  timing  requirements  for  the  subtokrai  can  be  satisfied  under  the 
timed-token  access  method. 

The  formal  model  for  the  improved  protocol  is  a  superset  of  FDDI.  With  the 
deletion  of  some  transitions  added  for  the  improved  protocol  and  small  changes  in  the 
MAC  Recover  and  Transmitter  state  diagrams  the  formal  model  becomes  the  original 
FDDI  or  FDDI-n  protocol.  Conceptually,  this  model  is  an  excellent  tool  for  development 
of  test  procedures  for  FDDI  stations  interoperability  achievement.  Therefore,  Protocol 
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Testing  of  FDDI,  FDDI-n  and  the  improved  FDDI  is  also  one  of  the  research  areas 
opoied  by  this  thesis. 
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